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1.1 INTRODUCTION 

This manual is intended to be used with the DSP56100 Family Manual (see Figure 1-1). 
The DSP56100 Family Manual provides a description of the components of the DSP561 6 
core that are common to all DSP56100 family processors and includes a detailed descrip- 
tion of the basic DSP561 00 family instruction set. The DSP56166 User's Manual provides 
a brief overview of the core processor and a detailed descriptions of the memory and pe- 
ripherals that are specific to the DSP56166. 
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Figure 1-1 DSP561 00 Family Product Literature 

A general block diagram of the DSP561 66 is shown in Figure 1 -2. It is available as a RAM 
based or ROM based part (see Section 3.3 for information on the ROM based part). The 
DSP56166 is optimized for applications such as medium to low bit rate speech encoding 
but can also be used in many other types of applications. 
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Figure 1-2 DSP561 66 RAM and ROM Based Functional Block Diagram 

Table 1-1 is a list of the DSP56166 primary features. The core features are common to 
any product using the DSP561 6 Core. Figure 1 -3 provides a more detailed block diagram 
of the DSP56166 RAM based part. 

1.2 DSP5616 CORE BLOCK DIAGRAM DESCRIPTION 

The heart of the DSP561 66 architecture is a 1 6-bit multiple-bus core processor called the 
DSP5616 which was designed specifically for real-time digital signal processing 
(DSP).The overall core architecture is presented here and can be seen in Figure 1-4. For 
a detailed description of the core processor, see the DSP56100 Family User's Manual. 

1.2.1 Data Buses 

Data movement on the chip occurs over three bidirectional 16-bit buses: the X Data Bus 
(XDB), the Program Data Bus (PDB) S and the Global Data Bus (GDB). Data transfer be- 
tween the Data ALU and the X Data Memory occurs over the XDB when one memory ac- 
cess is performed or over the XDB and the GDB when two simultaneous memory reads 
are performed. All other data transfers occur over the Global Data Bus. Instruction word 
pre-fetches take place in parallel over the PDB. The bus structure supports general reg- 
ister to register, register to memory, memory to register, and memory to memory data 
movement and can transfer up to three 1 6-bit words in the same instruction cycle. 
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Table 1-1 DSP56166 Feature List 



DSP5616 Core Features 

• Up to 30 Million Instructions per Second (MIPS) 
at 60 MHz- 33.3 ns instruction cycle 

• Single-cycle 16x1 6-bit parallel multiply- 
accumulate 

• 2 x 40-bit accumulators with extension byte 

• Fractional and integer arithmetic with support for 
multiprecision arithmetic 

• Highly parallel instruction set with unique DSP 
addressing modes 

• Nested hardware DO loops including infinite 
loops 

• Two instruction LMS adaptive filter loop 

• Fast auto-return interrupts 

• Three external interrupt request pins 

• Three 1 6-bit internal data buses and three 1 6-bit 
internal address buses 

• Programmable access time on the external bus 

• On-chip peripheral registers memory mapped in 
data memory space 

• Off-chip peripheral space with programmable 
access time memory mapped in data memory 
space 

• Low power wait and stop modes 

• On-Chip Emulation (OnCE) for unobtrusive, 
processor speed independent debugging 

• Operating frequency down to DC 

• 5V single power supply 

• Low power (HCMOS) 



DSP56166 On-chip Resources 

DSP56166 RAM Based Part: 

4K x 1 6 on-chip data RAM 

2K x1 6 on-chip program RAM 

One bootstrap ROM 

Bootstrap loading from external byte wide PROM, 

Host Interface, or Reduced Synchronous Serial 

Interface (RSSIO) 

DSP56166 ROM Based Part: 
4K x 1 6 on-chip data RAM 

4Kx1 6 on-chip data ROM 

256 x 16 on-chip program RAM 

8Kx1 6 on-chip program ROM 

DSP56166 RAM based and ROM Based Part: 

One external 1 6-bit address bus 

One external 1 6-bit data bus 

On-chip LA voice band codec (A/D-D/A) 

- Internal voltage reference (2/5 of positive 
power supply) 

- No off-chip components required 
25 general purpose I/O pins 
On-chip, programmable PLL 

Byte-wide Host Interface with DMA support 
Two independent reduced synchronous serial 

interfaces 
One 16-bit timer 
1 1 2 pin quad flat pack packaging 
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1 .2.2 Address Buses 

Addresses are specified for internal X Data Memory on two unidirectional 16-bit buses — 
X Address Bus One (XAB1) and X Address Bus Two (XAB2). Program memory address- 
es are specified on the PAB. External memory spaces are addressed via a single 16-bit, 
unidirectional address bus driven by a three input multiplexer that can select the XAB1 , 
XAB2, or PAB. One instruction cycle is needed for each external memory access. There 
is no speed penalty if only one externa! memory space is accessed in an instruction and 
if no wait states are inserted in the external bus cycle. If two or three external memory 
spaces are accessed in a single instruction, there will be a one or two instruction cycle 
execution delay, respectively, or more if wait states are inserted on the external bus. A 
bus arbitrator controls external accesses, making it transparent to the user. See the 
DSP56100 Family User's Manual for additional information. 
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Figure 1-3 DSP56166 RAM Based Part Block Diagram 

1.2.3 Data ALU 

The Data ALU performs all arithmetic and logical operations on data operands and con- 
sists of: 

- four 16-bit input registers, 

- two 32-bit accumulator registers, 

- two 8-bit accumulator extension registers, 

- an accumulator shifter, 

- an output shifter, 

- one data bus shifter/limiter, 

- one data bus limiter, 

- and a parallel, single cycle, non-pipelined Multiply-Accumulator (MAC) unit. 
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Figure 1-4 DSP561 6 Core Block Diagram 

Data ALU registers may be read or written via the XDB and GDB as 1 6-bit operands (see 
Figure 1-5). The Data ALU is capable of multiplication, multipiy-accumulate with positive 
or negative accumulation, addition, subtraction, shifting, and logical operations in one in- 
struction cycle. Data ALU arithmetic operations generally use fractional two's complement 
arithmetic. Some signed/unsigned and integer operations are also available. Data ALU 
source operands may be 16, 32, or 40 bits and may originate from input registers and/or 
accumulators. Data ALU results are always stored in one of the accumulators. The upper 
16-bits of an accumulator can be used as a multiplier input. Arithmetic operations always 
have a 40-bit result and logical operations are performed on 16-bit operands yielding 16- 
bit results in one of the two accumulators. 
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Figure 1-5 Data ALU Architecture Block Diagram 

The DSP56166 supports the two's complement representation of binary numbers. Un- 
signed numbers are only supported by the multiply and multiply-accumulate instruction. 
For fractional arithmetic, the 31 -bit product is added to the 40-bit contents of either the A 
or B accumulator. The 40-bit sum is stored back in the same accumulator. This multiply/ 
accumulate is a single cycle operation (no pipeline). Integer operations always generate 
a 16-bit result located in the accumulator MSP (A1 or B1). Full precision integer opera- 
tions are possible using the IMPY or IMAC instructions. Saturation arithmetic is provided 
to selectively limit overflow when reading a data ALU accumulator register. 

The DSP56166 implements two types of rounding: convergent rounding and two's com- 
plement rounding. The type of rounding is selected by the status register rounding bit (R 
bit). 

The logic unit in the MAC array performs the logical operations AND, OR, EOR, and NOT 
on data ALU registers. The logic unit is 1 6 bits wide and operates on data in the MSP por- 
tion of the accumulator. The LSP and EXT portions of the accumulator are not affected. 
See the DSP56100 Family User's Manual 'for additional information. 
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1 .2.4 Address Generation Unit (AGU) 

The AGU performs all address storage and effective address calculations necessary to 
address data operands in memory (see Figure 1 -6). This unit operates in parallel with oth- 
er chip resources to minimize address generation overhead. The AGU can implement 
three types of arithmetic: linear, modulo, and reverse carry. The Address ALU contains 
four address registers (R0-R3), four offset registers (N0-N3), and four modifier registers 
(M0-M3). The address registers are 1 6-bit registers which may contain addresses or data. 
Each address register may be output to the PAB and XAB1 . R3 may be output to XAB2 
when RO, R1 , or R2 are output to XAB1 . The modifier and offset registers are 16-bit reg- 
isters which are normally used to control updating of the address registers. Any register 
can also be used as a general purpose register for storage of 16-bit data. 
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Figure 1-6 AGU Block Diagram 
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AGU registers may be read or written by the GDB as 1 6-bit operands. The AGU can gen- 
erate two 16-bit addresses every instruction cycle: one for either the XAB1 or PAB and 
one for XAB2. The ALU can directly address 65536 locations on the XAB1 and 65536 lo- 
cations on the XAB2. See the DSP56100 Family User's Manualior additional information. 

1.2.5 Program Control Unit (PCU) 

The PCU performs instruction fetch, instruction decoding, hardware REP, DO loop con- 
trol, and exception processing. Two interrupt priority registers (IPR and IPR2) are used to 
program the priority level of the interrupts. They have control bits for the three external 
interrupt pins and each of the on-chip peripherals (see Figure 1-7, Table 1-4, Table 1-5 
and Table 1-6). 

There are 63 interrupts available and one reserved on the DSP56166. Table 1-2 shows 
each of these interrupts with their respective starting address and Interrupt Priority Level 
(IPL). The four level three interrupts are not maskable and if two or more are simulta- 
neously issued, their priority is (1) Hardware Reset, (2) Illegal Instruction, (3) Stack Error, 
and (4) the SWI instruction. The reserved interrupt is not available for use. 

The PCU contains five directly addressable registers in addition to the program counter 
(PC). These are the loop address (LA), loop counter (LC), status register (SR), operating 
mode register (OMR), and stack pointer (SP). The PC also contains a 15 level, 32-bit wide 
system stack memory. The 16-bit PC can address 65,536 locations in program memory 
space. See the DSP56100 Family User's Manualior additional information. 

1 .2.5.1 Interrupt Priority Structure 

Four levels of interrupt priority are provided. Interrupt priority levels (IPLs) numbered 0, 1 , 
and 2, are maskable with level as the lowest level. Level 3 (the highest level), is non- 
maskable. The only level 3 interrupts are Reset, Illegal Instruction, Stack Error and SWI. 
The interrupt mask bits (11, 10) in the status register reflect the current processor priority 
level and indicate the interrupt priority level needed for an interrupt source to interrupt the 
processor (see Table 1-3). Interrupts are inhibited for all priority levels less than the cur- 
rent processor priority level. However, level 3 interrupts are not maskable and therefore 
can always interrupt the processor. 



1-10 DSP561 66 OVERVIEW MOTOROLA 



/<flii 



DSP5616 CORE BLOCK DIAGRAM DESCRIPTION 





Table 1-2 Interrupt Sources 


interrupt 






Starting 






Address 


IPL 


Interrupt Source 


$0000 


3 


Hardware RESET 
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Illegal Instruction 
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3 
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$0008 
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SWI 
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IRQ A 


$000C 


0-2 


IRQB 


$000E 


0-2 


IRQC 


$0010 
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RSSI0 Receive Data with Exception Status 
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RSSI0 Receive Data 
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RSSIOTransmit Data with Exception Status 
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RSSI0 Transmit Data 
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RSSI1 Receive Data with Exception Status 
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RSSI1 Receive Data 
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RSSI1 Transmit Data with Exception Status 
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RSSI1 Transmit Data 
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Timer Compare 
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Host DMA Receive Data 
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Host DMA Transmit Data 
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0-2 


Host Receive Data 
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0-2 


Host Transmit Data 
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0-2 


Host Command (default) 
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Codec Receive/Transmit 


$0030 


0-2 


Available for Host Command 


$0032 


0-2 


Available for Host Command 


$0034 


0-2 


Available for Host Command 


$007E 


0-2 


Available for Host Command 
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Table 1-3 Status Register (SR) Interrupt Mask Bits 
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Exceptions 
Permitted 



IPL 0,1 ,2,3 

IPL 1,2,3 

IPL 2,3 

IPL 3 



Exceptions 
Masked 



None 

IPL0 

IPL 0,1 

IPL 0,1 ,2 
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Figure 1-7 Interrupt Priority Register IPR and IPR2 



Table 1-4 Interrupt Priority Level Bits 
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Table 1-5 External Interrupt Trigger Mode Bits 
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Table 1-6 Interrupt Priority Level Bits for IRQC 



ICL2 


ICL1 


Enabled 


IPL 





1 
1 




1 



1 


Not enabled 

Level 
Not Enabled 
Neg. Edge 


1 
1 
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1 .2.5.2 Interrupt Priority Levels (IPL) 

The interrupt priority level for each on-chip peripheral device and for each external inter- 
rupt source (IRQA, IRQB, IRQC) can be programmed under software control. Each on- 
chip or external peripheral device can be programmed to one of the three maskable pri- 
ority levels (IPL 0, 1 , or 2). Interrupt priority levels are set by writing to the Interrupt Priority 
Registers IPR and IPR2 shown in Figure 1-7. These read/write registers specify the inter- 
rupt priority level for each of the interrupting devices (Codec, Host, RSSIs, Timer, IRQA, 
IRQB, IRQC). In addition, this register specifies the trigger mode of both external interrupt 
sources IRQA, IRQB and it is used to enable or disable the individual external interrupts. 
This register is cleared on RESET. Table 1 -4 defines the interrupt priority level bits. Table 
1 -5 defines the external interrupt trigger mode bits for IRQA, IRQB. Table 1 -6 defines the 
interrupt priority level for the third external interrupt IRQC. 

1 .2.5.3 Exception Priorities within an IPL 

If more than one exception is pending when an instruction is executed, the interrupt with 
the highest priority level is serviced first. When multiple interrupt requests with the same 
IPL are pending, a second fixed priority structure within that IPL determines which inter- 
rupt is serviced. The fixed priority of interrupts within an IPL and the interrupt enable bits 
for all interrupts are shown in Table 1 -7. The interrupt enable bits for the Host, RSSIs, and 
TM are located in the control registers associated with their respective on-chip peripher- 
als. 

1 .3 MEMORY ORGANIZATION 

Two independent memory space configurations (X data and P program), are described in 
section 3. These memory spaces are configured by control bits in the Operating Mode 
Register, OMR. MA and MB control the program memory map and EX controls the data 
memory map. 



MffQR0LA 



DSP56166 OVERVIEW 



lillll 



EXTERNAL BUS, 1/0$ and ON-CHIP PERIPHERALS 



Table 1-7 Exception Priorities within an IPL 



Priority 


Exception 


Enabled by 


IP Reg. 
Bit No. 


Control 
Register 
Address 


Level 3 (Non-maskable) 


Highest 


Hardware RESET 


— 


— 


— 




Illegal Instruction Interrupt 


— 


— 


— 




Stack Error 


— 


— 


— 


Lowest 


SWI 


— 


— 


— 


Level 0, 1, 2 (Maskable) 


Highest 


IRQA (External Interrupt) 


IRQA 

mode bits 


0,1 


X:$FFDF 




IRQB (External Interrupt) 


IRQB 
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X:$FFDF 
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15 
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TIE 
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Timer Overflow Interrupt 
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Timer Compare Interrupt 
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1 .4 EXTERNAL BUS, l/Os and ON-CHIP PERIPHERALS 

Five on-chip peripherals are provided on the DSP56166: an 8-bit parallel Host MPU/DMA 
Interface, a 1 6-bit timer, two Reduced Synchronous Serial Interfaces (RSSI1 and RSSIO), 
and a sigma-delta codec (see Figure 1 -2). The DSP561 66 provides 1 6 pins for an external 
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address bus and 1 6 pins for an external data bus. These pins are grouped to form the Port 
A bus interface. The DSP561 66 also provides 25 programmable I/O pins. These pins may 
be used as general purpose I/O pins or allocated to an on-chip peripheral. They are sep- 
arate from the DSP561 66 codec, address buses, and data buses and are grouped as two 
I/O ports (B and C). 

Port B is a 15-pin I/O interface that may be used as a general purpose I/O or as a Host 
MPU/DMA Interface. The Host MPU/DMA Interface provides a dedicated 8-bit parallel 
port to a host microprocessor or DMA controller and can provide debugging facilities via 
host exceptions. 

Port C is a 1 0-pin I/O interface that may be used as a general purpose I/O or as a Timer 
and two identical Reduced Synchronous Serial Interfaces. 

The sigma-delta codec has seven dedicated pins which are not available as general pur- 
pose I/O. Both analog to digital (A/D) and digital to analog (D/A) converters are provided 
on-chip. The final decimation, antialiasing and compensation filters for the A/D and inter- 
polation, reconstruction, and compensation filters for the D/A converter are implemented 
in software on the DSP providing the user considerable flexibility in the codec filter char- 
acteristics. 

1.4.1 Memory Expansion Port (Port A) 

The DSP561 66 expansion port is designed to synchronously interface over a common 1 6- 
bit data bus with a wide variety of memory and peripheral devices such as high speed stat- 
ic RAMs, slower memory devices, DSPs, and MPUs in master/slave configurations. This 
capability is possible because the external bus cycle time is programmable. The expan- 
sion bus timing is controlled by a two Bus Control Registers (BCR & BCR2). The bus con- 
trol registers control the timing of the bus interface signals and data lines. Each of the two 
memory spaces, X data and Program data, has its own 5 control bits in the BCR which 
can be programmed for up to 31 wait states (one wait state is equal to a clock period, or 
equivalent^, one-half of an instruction cycle). The access time on the external peripheral 
memory space can be controlled with 5 control bits in BCR2. In this way, external bus tim- 
ing can be tailored to match the speed requirements of the different memory spaces or 
external peripherals. 

1 .4.2 General Purpose I/O (Port B, Port C) 

Each Port B and C pin may be programmed as a general purpose I/O pin or as a dedicated 
on-chip peripheral pin under software control. A 10-bit Port Control Register, PCC, is as- 
sociated with Port C and allows each port pin to be programmed individually for one of 
these two functions. The port control register associated with Port B, PBC, contains only 
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one bit which programs all 15 pins. Also associated with each general purpose port is a 
data direction register which programs each pin as an input or output, and a data register 
for data I/O. 

1.4.3 RSSIO and RSSI1 

The DSP56166 provides two identical Reduced Synchronous Serial Interfaces (RSSPs). 
They are extremely flexible, full-duplex serial interfaces which allow the DSP56166 to 
communicate with a variety of serial devices. These interfaces include one or more indus- 
try standard codecs, other DSPs, microprocessors, and peripherals. The RSSIx interface 
consists of a transmitter and a receiver section and a transmit/receive RSSI clock gener- 
ator. Each of the following characteristics of the RSSI can be independently defined: the 
number of bits per word, the protocol or mode, and the clock.The transmit and receive 
sections are synchronous. Three modes of operation are available: Normal, Network, and 
Gated. The Normal Mode is typically used to interface with devices on a regular or peri- 
odic basis. In this mode, the RSSI functions with one data word of I/O per frame. The Net- 
work Mode provides time slots in addition to a bit clock and a frame synchronization pulse. 
The RSSI functions with 2 to 8 words of I/O per frame in the Network Mode. This mode is 
typically used in star or ring Time Division Multiplex (TDM) networks with other 
DSP561 66s and/or codecs. The clock can be programmed to be continuous or gated. The 
RSSI supports a subset of the Motorola SPI interface. The RSSI requires three to four pins 
depending on the operating mode selected. 

1 .4.4 Timer 

The Timer is a general purpose 16-bit timer/event counter with internal or external clock- 
ing which can be used to interrupt the DSP or to signal an external device at periodic in- 
tervals, after counting internal events or after counting external events. A Timer Input pin 
(TIN) can be used as an event counter input and a Timer Output pin (TOUT) can be used 
for timer pulse or timer clock generation. 

The timer includes three 1 6-bit registers: the Timer Count Register (TCTR), the Timer Pre- 
load Register (TPR), and the Timer Compare Register (TCPR). An additional Timer Con- 
trol Register (TCR) controls the timer operations. 

A decrement register, programmed by the control register, is not available to the user. All 
other registers are memory mapped read/write registers. 

1.4.5 Host Interface (HI) 

The HI is a byte-wide parallel slave port which may be connected directly to the data bus 
of a host processor. The host processor may be any of a number of popular microcom- 
puters or microprocessors, another DSP, or DMA hardware. The HI is composed of an 8- 
bit bidirectional data bus and 7 control lines to control data transfers. The HI appears as 
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a memory mapped peripheral, occupying 8 bytes in the host processor's address space 
and three words in the DSP processor's address space. Separate transmit and receive 
data registers are double-buffered to allow the DSP561 66 and host processor to efficient- 
ly transfer data at high speed. Host processor communication with the HI registers is ac- 
complished using standard host processor instructions and addressing modes. Host 
processors may use byte move instructions to communicate with the HI registers. The 
host registers are addressed so that 8-bit MC6801-type host processors can use 16-bit 
load (LDD) and store (STD) instructions for data transfers. The 1 6-bit MC68000/1 host 
processor can address the HI using the special MOVEP instruction for word (16-bit) or 
long word (32-bit) transfers. The 32-bit MC68020 host processor can use its dynamic bus 
sizing feature to address the HI using standard MOVE word (16-bit), long word (32-bit) or 
quad word (64-bit) instructions. 

One of the most innovative features of the HI is the Host Command feature. With this fea- 
ture, the host processor can issue vectored exception requests to the DSP56166. The 
host may select any one of 63 DSP56166 exception routines to be executed by writing a 
Vector Address Register in the HI. This flexibility allows the host programmer to execute 
up to 63 functions preprogrammed in the DSP56166. 

1.5 OnCE 

OnCE provides hardware/software emulation and debug on the DSP56166 and a means 
of interacting with the DSP56166 and any memory mapped peripherals non-intrusively so 
that a user may examine registers, memory, or peripherals. To achieve this, special cir- 
cuits and dedicated pins on the DSP are used to avoid sacrificing any user accessible on- 
chip resource. A key feature of the special OnCE pins is to allow the user to insert the 
DSP56166 into his target system yet retain debug control, especially in the case of devic- 
es specified without an external bus. The need for a costly cable which brings out all pro- 
cessor pins on a traditional emulator system is eliminated. 

1 .6 PROGRAMMING MODEL 

The DSP561 66 is based on the DSP5616 core. The programmer can view the DSP5616 
core architecture as three execution units operating in parallel. The three execution units 
are the Data ALU, Address Generation Unit, and Program Control Unit. The programming 
model appears like that of a conventional MPU. The programming model is shown in Fig- 
ure 1-8 and is described in the following paragraphs. 

1.6.1 Data ALU 

The data ALU features four 16-bit input/output data registers which can be concatenated 
to handle 32-bit data, two 40-bit accumulators, automatic scaling, and saturation arith- 
metic. 



m 
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1 .6.1 .1 Data ALU Input Registers (XI , XO, Y1 , YO) 

X1 , XO, Y1 , and YO are 1 6-bit latches which serve as input pipeline registers for the data 
ALU. Each register may be read or written by the XDB. XO, X1 , and YO may be written 
over the GDB. They may be treated as four independent 16-bit registers or as two 32-bit 
registers called X and Y which are developed by the concatenation of X1 :X0 and Y1 :Y0 
respectively. X1 is the most significant word in X and Y1 is the most significant word in Y. 

These Data ALU input registers are used as source operands for most data ALU opera- 
tions and allow new operands to be loaded for the next instruction while the register con- 
tents are being used by the current instruction. 

1 .6.1 .2 Data ALU Accumulator Registers (A2, A1 , AO, B2, B1 , BO) 

A1 , AO, B1 , and BO are 1 6-bit latches that serve as data ALU accumulator registers. A2 
and B2 are 8-bit latches that serve as accumulator extension registers. Each register may 
be read or written by the XDB as a word operand. A1 and B1 may be written by the GDB. 
When A2 or B2 is read, the register contents occupy the low-order portion (bits 7-0) of the 
word; the high-order portion (bits 16-8) is sign-extended. When A2 or B2 is written, the 
register receives the low-order portion of the word; the high-order portion is not used. Au- 
tomatic sign extension of the 40-bit accumulators is provided when the A or B register is 
written with a smaller size operand. If the A or B register is written with a 1 6-bit value, then 
the least significant 1 6 bits are set to zero. 

It is also possible to saturate the accumulator on a 32-bit value automatically after every 
accumulation. Overflow protection is performed after the contents of the accumulator 
have been shifted according to the scaling mode defined in the status register. When lim- 
iting occurs, the L bit flag in the status register is set and latched. 
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1 .6.2 Address Generation Unit 

The programmer's model for the address generation unit consists of three banks of reg- 
ister files — pointer register files, offset register files, and modifier register files. These 
provide all the registers necessary to generate address register indirect effective address- 
es. 

1 .6.2.1 Address Register File (R0-R3) 

The address register file consists of four, sixteen-bit registers. The file contains the ad- 
dress registers R0-R3 which usually contain addresses used as pointers to memory. Each 
register may be read or written by the Global Data Bus. Each address register may be 
used as an input to the modulo arithmetic unit for a register update calculation. Each reg- 
ister may be written by the GDB or by the output of the modulo arithmetic unit. 

1 .6.2.2 Offset Register File (N0-N3) 

The offset register file consists of four, sixteen-bit registers. The file contains the offset 
registers N0-N3 and usually contains offset values used to update address pointers. Each 
offset register may be read or written by the Global Data Bus. Each offset register is used 
as an input to the modulo arithmetic unit when the same number address register is read 
and used as an input to the modulo arithmetic unit. 

1 .6.2.3 Modifier Register File (M0-M3) 

The modifier register file consists of four, 16-bit registers. The file contains the modifier 
registers M0-M3 and usually specifies the type of arithmetic used to modify an address 
register during address register update calculations — linear, modulo, or reverse carry. 
Each modifier register may be used as an input to the modulo arithmetic unit or written by 
the Global Data Bus. Each modifier register is read when the same number address reg- 
ister is read and used as an input to the modulo arithmetic unit. Each modifier register is 
preset to $FFFF during a processor reset. Note that when R3 is used for the second read 
of a dual read operation, only linear arithmetic is available on this address register. 

1 .6.3 Program Control Unit 

The program control unit features loop address and loop counter registers which are ded- 
icated to supporting the hardware DO loop instruction in addition to the standard program 
flow control resources such as a program counter, status register, and system stack. With 
the exception of the program counter, all registers are read/write to facilitate system de- 
bug. 

1 .6.3.1 Program Counter (PC) 

This 16-bit register contains the address of the next location to be fetched from program 
memory space. The PC may point to instructions, data operands, or addresses of oper- 
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Figure 1-9 Status Register Format 

ands. References to this register are always inherent and are implied by most instructions. 
This special purpose address register is stacked when program looping is initiated, when 
a branch or a jump to subroutine is performed, and when interrupts occur (except for fast 
interrupts). 

1 .6.3.2 Status Register (SR) 

The SR is a 16-bit register consisting of an 8-bit Mode Register (MR) and an 8-bit Condi- 
tion Code Register (CCR) — see Figure 1-9. The MR register is the high-order 8 bits of 
the SR; the CCR register is the low-order 8 bits. 

The MR bits are only affected by processor reset, exception processing, the DO, ENDDO, 
RTI, and SWI instructions and by instructions which directly reference the MR register 
(e.g., MOVE, ANDI, ORI). During processor reset, the interrupt mask bits of the mode reg- 
ister will be set, the scaling mode bits, loop flag, and the forever flag will be cleared. The 
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CCR is a special purpose control register which defines the current user state of the pro- 
cessor at any given time. The CCR bits are affected by data ALU operations, one address 
ALU operation (CHKAAU), bit field manipulation instructions, parallel move operations, 
and by instructions which directly reference the CCR register. The CCR bits are not af- 
fected by data transfers over XDB except when data limiting occurs while reading the A 
or B accumulators or by the conditions described for the Sticky Bit, Bit 7. During processor 
reset, all CCR bits are cleared. The SR register is stacked when program looping is ini- 
tialized, when a jump or branch to subroutine (JScc, BScc, JSR, BSR) is performed, and 
when long interrupts occur. 

1 .6.3.3 Loop Counter (LC) 

The LC is a special 16-bit counter used to specify the number of times to repeat a hard- 
ware program loop. This register is stacked by a DO instruction and unstacked by end of 
loop processing or by execution of a BRKcc or an ENDDO instruction. When the end of a 
hardware program loop is reached, the contents of the loop counter register are tested for 
one. If the LC is one, the program loop is terminated and the LC register is loaded with 
the previous LC contents stored on the stack. If the LC is not one, it is decremented by 
one and the program loop is repeated. The LC may be read under program control. This 
allows the number of times a loop has been executed to be determined during execution. 
Note that if LC=0 during execution of the DO instruction, the loop will not be executed and 
the program will continue with the instruction immediately after the loop end of expression. 
LC is also used by the REP instruction. 

1 .6.3.4 Loop Address Register (LA) 

The LA indicates the location of the last instruction word in a program DO loop. This reg- 
ister is stacked by a DO instruction and unstacked by end of loop processing or by exe- 
cution of an ENDDO or BRKcc instruction. When the instruction word at the address 
contained in this register is fetched, the content of LC is checked. If it is not one, the LC 
is decremented and the next instruction is taken from the address at the top of the system 
stack. Otherwise; the PC is incremented, the loop flag is restored (pulled from stack), the 
stack pointer is decremented by two, the LA and LC registers are pulled from the stack 
and restored, and instruction execution continues normally. The LA register is a read/write 
register written into by a DO instruction. 

1 .6.3.5 System Stack (SS) 

The SS is a separate internal RAM, 15 locations "deep", and divided into two 16-bit wide 
banks: High (SSH) and Low (SSL). SSH stores the PC and LA contents; SSL stores the 
LC and SR contents. The PC and SR registers are pushed on the stack for subroutine 
calls and long interrupts. These registers are pulled from the stack for subroutine returns 
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using the RTS instruction (PC only) and for interrupt returns that use the RTI instruction. 
The system stack is also used for storing the address of the beginning instruction of a 
hardware program loop as well as the SR, LA, and LC register contents just prior to the 
start of the loop. This allows nesting of DO loops. 

Up to 15 long interrupts, 7 DO loops, or 1 5 JSRs or combinations of these can be accom- 
modated by the stack. Care must be taken when approaching the stack limit. When the 
Stack limit is exceeded, the data to be stacked will be lost and a non-maskable Stack Error 
interrupt will occur. The stack error interrupt occurs after the stack limits have been ex- 
ceeded. 

1 .6.3.6 Stack Pointer (SP) 

The SP is a 6-bit register that indicates the location of the top of the SS and the stack sta- 
tus (underflow, empty, full, and overflow conditions - see Table 1 -8). The SP is referenced 
implicitly by some instructions (DO, REP, JSR, RTI, etc.) or directly by the MOVEC in- 
struction. Note that the stack pointer register is implemented as a 6-bit counter which ad- 
dresses (selects) a fifteen location stack with its four least significant bits. 

Table 1-8 Stack Pointer Values 



- 



UF SE P3 P2 P1 PO 


CAUSE 


1 11110 
1 11111 

1 

1110 
1111 
10 
10 1 


<- Stack Underflow condition after double pull. 
<r- Stack Underflow condition. 
<r- Stack Empty (reset). Pull causes underflow. 
<- stack location 1 . 

<r- Stack location 1 4. 

<- Stack location 1 5 (stack full). Push causes overflow. 

<- Stack Overflow condition. 

<r- Stack Overflow condition after double push. 



1.6.3.7 Operating Mode Register (OMR) 

The OMR is a 16-bit register which defines the current processor operating mode. The 
OMR bits are only affected by processor reset and by instructions which directly reference 
the OMR. 

The operating mode register format is shown in Figure 1-10. 
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Figure 1-10 Operating Mode Register (OMR) 



Stop Delay 

- Clockout Disable 

Reserved 



During processor reset, the chip operating mode bits will be loaded from the external 
Mode Select pins. Table 1 -9 summarizes the operating modes for the 561 66 RAM based 
part and Table 1-10 does the same for the ROM based part. 

Table 1-9 Operating Mode Summary — DSP56166 RAM Based Part 



Operating 
Mode 


M 
B 


M 
A 


Description 


Special 
Bootstrap 1 








Bootstrap from an external 
byte-wide memory located 
at P:$C000. 


Special 
Bootstrap 2 





1 


Bootstrap from the host port 
or RSSIO 


Normal 
Expanded 


1 





Internal PRAM enabled; 
external reset at P:$E000 


Development 
Expanded 


1 


1 


Internal program RAM 
disabled; external reset at 
P:$0000. 
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Table 1-10 Operating Mode Summary — DSP56166 ROM Based Part 






MB 


MA 


Chip Operating 
Mode 


Reset Vector 


Program Memory 
Configuration 












Single Chip 


Internal Pmem P:$0 


Internal Pmem Enabled 









1 


Single Chip 


Internal Pmem P:$100 


Internal Pmem Enabled 






1 





Normal Expanded 


External Pmem P:$E000 


Internal Pmem Enabled 






1 


1 


Development 


External Pmem P:$0 


Internal Pmem Disabled 
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*: the address will be the first location of the internal PROM. 

The Mode C bit (MC) selects the initial bus operating mode.When set, the external bus is 
programmed in the master mode (BR output and BG input) and when cleared, the bus is 
programmed in the slave mode (BR input and BG output). 

The EX bit, when set, will force all accesses to the X data memory to be external access- 
es, preventing access to on-chip data memory and on-chip peripheral space.This allows 
a continuous memory map when using 64K of external data memory. When the EX bit is 
set, the memory mapped I/O registers, both on and off-chip, can only be accessed during 
fast interrupt. During normal operation and during a long interrupt, the EX bit must be ex- 
plicitly cleared by the user's code before the on-chip data memory and the memory 
mapped I/O registers can be read or written. The on-chip peripherals, however, will still 
be active and interrupts will still be recognized. Special care should be taken with this bit 
in a nested interrupt environment since it is not in the Status Register (SR) and thus is not 
stacked with each new interrupt. Note that OnCE cannot read the content of on-chip X 
memories, registers and peripherals when the EX bit is set, but it can still write to them. 

The Saturation bit (SA), when set, selects automatic saturation on 32 bits for the results 
from the MAC array back to the accumulator. This saturation is done by a special satura- 
tion circuit inside the MAC unit. The purpose of this bit is to provide a saturation mode for 
1 6-bit algorithms which do not recognize or cannot take advantage of the extension accu- 
mulator. The saturation logic operates by checking three bits of the 40-bit result: two bits 
of the extension byte (exp[7] and exp[0]) and one bit on the MSP (msp[15]). The result 
obtained in the accumulator when SA =1 is shown in Table 1-11. 

The Rounding bit (R)selects between convergent rounding and two's complement round- 
ing. When set, two's complement rounding (always round up) is used. 

The Stop Delay bit (SD) is used to select the delay that the DSP needs to exit the STOP 
mode. 
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Table 1-11 Actions of the Saturation Mode (SA=1) 



exp[7] 


exp[0] 


msp[15] 


result in accumulator 







1 
1 
1 
1 





1 

1 




1 
1 



1 


1 



1 



1 


unchanged 
$00 7FFF FFFF 
$00 7FFF FFFF 
$00 7FFF FFFF 

$FF 8000 0000 

$FF 8000 0000 

$FF 8000 0000 

unchanged 



When the Clock out Disable bit (CD) is cleared in the OMR, the CLKO pin provides a clock 
to external circuitry. Setting the CD bit will disable this signal one instruction cycle after 
the bit has been set. 

Note: When a bit of the OMR is changed by an instruction, a delay of one instruction cycle 
is necessary before the new mode comes into effect. 

1 .7 INSTRUCTION SET SUMMARY 

As indicated by the programming model, the DSP architecture can be viewed as three 
functional units operating in parallel (Data ALU, AGU, and PCU). The goal of the instruc- 
tion set is to keep each of these units busy each instruction cycle. This achieves maximum 
throughput and minimum use of program memory. 

This section introduces the DSP instruction set and instruction format. The complete 
range of instruction capabilities combined with the flexible addressing modes provide a 
very powerful assembly language for digital signal processing algorithms. The instruction 
set has also been designed to allow efficient coding for future high-level DSP language 
compilers. Execution time is enhanced by the hardware looping capabilities. 

1.7.1 Instruction Groups 

The instruction set is divided into the following groups: 

- Arithmetic 

- Logical 

- Bit Field Manipulation 

- Loop 

- Move 

- Program Control 

Each instruction group is described in the following sections. Detailed information on each 
instruction is given in Appendix A of the DSP56100 Family User's Manual. 
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1 .7.1 .1 Arithmetic Instructions 

The arithmetic instructions perform all of the arithmetic operations within the Data ALU. 
They may affect all of the condition code register bits. Arithmetic instructions are register- 
based (register direct addressing modes used for operands) so that the Data ALU opera- 
tion indicated by the instruction does not use the XDB or the GDB. Optional data transfers 
may be specified with most arithmetic instructions. This allows for parallel data movement 
over the XDB and over the GDB during a Data ALU operation. This allows new data to be 
prefetched for use in subsequent instructions and allows results calculated by previous 
instructions to be stored. These instructions execute in one instruction cycle. The follow- 
ing are the arithmetic instructions. 

ABS Absolute Value 

ADC Add Long with Carry* 

ADD Add t 

ASL Arithmetic Shift Left 

ASL4 4-Bit Arithmetic Shift Left* 

ASR Arithmetic Shift Right 

ASR4 4-Bit Arithmetic Shift Right* 

ASR1 6 1 6-Bit Arithmetic Shift Right* 

CHKAAU Update the V, Z, N flags according to the address calculation result* 

CLR Clear an Accumulator 

CLR24 Clear 24 MSBs of an Accumulator 

CMP Compare 

CMPM Compare Magnitude 

DEC Decrement Accumulator 

DEC24 Decrement upper 24 bits of Accumulator 

DIV Divide Iteration* 

DMAC Double (Multi) precision oriented MAC* 

EXT Sign Extend Accumulator from bit 31 * 

IMAC Integer Multiply-Accumulate* 

IMPY Integer Multiply* 

INC Increment Accumulator 

INC24 Increment 24 MSBs of Accumulator 

MAC Signed Multiply-Accumulate t 

MACR Signed Multiply-Accumulate and Round f 

MPY Signed Multiply f 

MPYR Signed Multiply and Round t 

MPY(su,uu) Mixed Mode Multiply* 
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MAC(su,uu) Mixed Mode Multiply-Accumulate* 

NEG Negate 

NEGC Negate with Borrow* 

NORM Normalize* 

RND Round 

SBC Subtract Long with Carry 

SUB Subtract f 

SUBL Shift Left and Subtract 

SWAP Swap MSP and LSP of an Accumulator* 

Tec Transfer Conditionally* 

TFR Transfer Data ALU Register (Accumulator as destination) f 

TFR2 Transfer Accumulator (32-bit Data Alu register as destination)* 

TST Test an accumulator 

TST2 Test an ALU data register* 

ZERO Zero Extend Accumulator from bit 31 * 

*These instructions do not allow parallel data moves, 
t These instructions allow a dual read parallel move. 

1 .7.1 .2 Logical Instructions 

The logical instructions perform all of the logical operations within the Data ALU. They 
may affect all of the condition code register bits. Logical instructions are register-based as 
are the arithmetic instructions above. Optional data transfers may be specified with most 
logical instructions. With the exceptions of ANDI and ORI instructions, the destination of 
all logical instructions is A1 or B1 . These instructions execute in one instruction cycle. The 
following are the logical instructions. 



AND 

ANDI 

EOR 

LSL 

LSR 

NOT 

OR 

ORI 

ROL 

ROR 



Logical AND 

AND Immediate Program Controller Register* 

Logical Exclusive OR 

Logical Shift Left 

Logical Shift Right 

Logical Complement 

Logical Inclusive OR 

OR Immediate Program Controller Register* 

Rotate Left 

Rotate Right 



*These instructions do not allow parallel data moves. 
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1.7.1.3 Bit Field Manipulation Instructions 

This group tests the state of any set of bits within a byte in a memory location or a register 
and then sets, clears, or inverts bits in this byte. Bit fields which can be tested include the 
upper byte and the lower byte in a 1 6-bit value. The carry bit of the condition code register 
will contain the result of the bit test for each instruction. These instructions are read-mod- 
ify-write and require two instruction cycles. Parallel data moves are not allowed with any 
of these instructions. The following are the bit field manipulation instructions. 

BFTSTL Bit Field Test Low 

BFTSTH Bit Field Test High 

BFCLR Bit Field Test and Clear 

BFSET Bit Field Test and Set 

BFCHG Bit Field Test and Change 

1 .7.1 .4 Loop Instructions 

The loop instructions control hardware looping by initiating a program loop and setting up 
looping parameters, or by "cleaning" up the system stack when terminating a loop. Initial- 
ization includes saving registers used by a program loop (LA and LC) on the system stack 
so that program loops can be nested. The address of the first instruction in a program loop 
is also saved to allow no-overhead looping. The end address of the DO loop is specified 
as PC relative. Parallel data moves are not allowed with any of these instructions. The fol- 
lowing are the loop instructions. 

DO Start Hardware Loop 

DO FOREVER Hardware Loop Forever 

ENDDO Disable Current Loop and Unstack Parameters 

BRKcc Conditional Exit from Hardware Loop 

1 .7.1 .5 Move Instructions 

The move instructions perform data movement over the XDB and over the GDB. Move 
instructions do not affect the condition code register except for the limit bit, L, if limiting is 
performed or the Sticky Bit, S, when reading a Data ALU accumulator register. AGU in- 
structions are also included among the following move instructions. These instructions do 
not allow optional data transfers. 

LEA Load Effective Address 

MOVE Move Data with or without Register Transfer - TFR(3) 

MOVE(C) Move Control Register 

MOVE(I) Move Immediate Short 

MOVE(M) Move Program Memory 
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MOVE(P) Move Peripheral Data 

MOVE(S) Move Absolute Short 

1 .7.1 .6 Program Control Instructions 

The program control instructions include branches, jumps, conditional branches, jumps 
and other instructions which affect the PC and system stack. Program control instructions 
may affect the condition code register bits as specified in the instruction. Parallel data 
moves are not allowed with any of these instructions. The following are the program con- 
trol instructions. 

Bcc Branch Conditionally (PC relative) 

BSR Branch to Subroutine (PC relative) 

BRA Branch (PC relative) 

BScc Branch to Subroutine Conditionally (PC relative) 

DEBUG Enter Debug Mode 

DEBUGcc Enter Debug Mode Conditionally 

Jcc Jump Conditionally 

JMP Jump 

JSR Jump to Subroutine 

JScc Jump to Subroutine Conditionally 

NOP No Operation 

REP Repeat Next Instruction 

REPcc Repeat Next Instruction Conditionally 

RESET Reset Peripheral Devices 

RTI Return from Interrupt 

RTS Return from Subroutine 

STOP Stop Processing (low power stand-by) 

SWI Software Interrupt 

WAIT Wait for Interrupt (low power stand-by) 

1.7.2 Instruction Formats 

Instructions are one or two words in length. The instruction and its length are specified by 
the first word of the instruction. The next word may contain information about the instruc- 
tion itself or about an operand for the instruction. The assembly language source code for 
a typical one word instruction is shown below. The source code is organized into four col- 
umns. 
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Opcode Operands X Bus Data G Bus Data 

MAC X0,Y0,A X:(R0)+,X0 X:(R3)+,Y0 

The Opcode column indicates the Data ALU, AGU, or PCU operation to be performed. 
The Operands column specifies the operands to be used by the opcode. The X Bus Data 
and G Bus Data columns specify optional data transfers over the X Bus, the G bus, and 
the addressing modes to be used. The Opcode column must always be included in the 
source code. 

The DSP offers parallel processing using the Data ALU, AGU, and PCU. For the instruc- 
tion word above, the DSP will perform the designated ALU operation (Data ALU), up to 
two data transfers specified with address register updates (AGU), and will also decode 
the next instruction and fetch an instruction from program memory (PCU), all in one in- 
struction cycle. When an instruction is more than one word in length, an additional instruc- 
tion execution cycle is required. Most instructions involving the Data ALU are register- 
based (all operands are in Data ALU registers) and allow the programmer to keep each 
parallel processing unit busy. An instruction which is memory-oriented (such as a bit field 
manipulation instruction) or that causes a control flow change (such as a branch/jump) 
prevents the use of parallel processing resources during its execution. See the DSP56100 
Family User's Manual for additional information. 

1.7.3 Addressing Modes 

The addressing modes are grouped into three categories — register direct, address reg- 
ister indirect, and special. These addressing modes are summarized in Table 1 -1 2. All ad- 
dress calculations are performed in the address generation unit to minimize execution 
time. Addressing modes specify whether the operand(s) is(are) in a register, memory, or 
encoded in the instruction as immediate data. 

The register direct addressing mode can be subclassified according to the specific regis- 
ter addressed. The data registers include X1 , XO, Y1 , YO, X, Y, A2, A1 , AO, B2, B1 , BO, 
A, and B. The control registers include SR, OMR, SP, SSH, SSL, LA, LC, CCR, and MR. 

Address register indirect modes use an address register, Rn, to point to locations in mem- 
ory. The content of Rn is the effective address (ea) except in the indexed by offset mode 
where the ea is Rn+Nn, or in the indexed by short displacement where the ea is Rn+a 
short immediate constant. Address register indirect modes use a modifier register, Mn, to 
specify the type of arithmetic to be used to update Rn. If a mode using an offset is speci- 
fied, an offset register, Nn, is also used for the update. The Nn and Mn registers are as- 
signed to the Rn with the same n. Thus, the assigned register sets are R0;N0;M0, 
R1 ;N1 ;M1 , R2;N2;M2, and R3;N3;M3. 
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Table 1-12 DSP561 6 Addressing I 


Mo< 


Jes 










Addressing Mode 


Uses Mn 
Modifier 


Operand Reference 


S 


C 


D 


A 


p 


X 


XX 


Register Direct 


Data or Control Register 
Address Register Rn 
Address Modifier Register Mn 
Address Offset Register Nn 


No 
No 
No 
No 


X 


X 


X 


X 
X 
X 








Address Register Indirect 


No Update 
Postincrement by 1 
Postdecrement by 1 
Postincrement by Offset Nn 
Indexed by Offset Nn 
Predecrement by 1 


No 
Yes* 
Yes 
Yes* 
Yes 
Yes 










X 
X 
X 
X 


X 
X 
X 
X 
X 
X 


X 
X 


PC Relative 


Long Displacement 
Short Displacement 
Address Register 


No 
No 
No 




X 
X 
X 




X 


X 
X 
X 






Special 


Upper word of accumulator 

Immediate Data 

Immediate Short Data 

Absolute Address 

Absolute Short Address 

Short Jump Address 

I/O Short Address 

Implicit 

Indexed by short displacement 


No 
No 
No 
No 
No 
No 
No 
No 
No 


X 


X 






X 
X 
X 
X 
X 

X 


X 

X 
X 

X 

X 




Where: 

S = System Stack Reference 

P = Program Memory Reference 

C =Program Controller Register Reference 

X = X Memory Reference 

D = Data ALU Register Reference 

XX = Double X Memory Read 

A = Address ALU Register Reference 


*Note: M3 is not used for updating R3 in the second read in the X memory 



This structure is unique and extremely powerful in general, and particularly powerful in 
setting up DSP oriented data structures. Two sets of address registers can be used by the 
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instruction set: one set for the first memory operation and one set for a second memory 
operation. Note that M3 is not used for updating R3 in the second read in the X memory. 

The special addressing modes include immediate and absolute modes as well as implied 
references to the PC, system stack, and program memory. In addition, it is possible to use 
the upper word (MSP) of an accumulator as an address. 

1 .7.4 Address Arithmetic 

The DSP56166 Address Generation Unit supports linear, modulo, and bit-reversed ad- 
dress arithmetic for all address register indirect modes. The address modifiers, Mn, deter- 
mine the type of arithmetic used to update addresses. Address modifiers allow the 
creation of data structures in memory for FIFOs (queues), delay lines, circular buffers, 
stacks, and bit-reversed FFT buffers. Data is manipulated by updating address registers 
(pointers) rather than moving large blocks of data. The contents of the address modifier 
register, Mn, defines the type of address arithmetic to be performed for addressing mode 
calculations, and for the case of modulo arithmetic, the content of Mn also specifies the 
modulus. Each address register Rn has its own modifier register Mn associated with it. 

1 .7.4.1 Linear Modifier 

Address modification is performed using normal 16-bit (modulo 65,536) two's comple- 
ment linear arithmetic. A 16-bit offset Nn, or immediate data (+1, -1, or a displacement 
value) may be used in the address calculations. The range of values may be considered 
as signed (Nn from -32,768 to +32,767) or unsigned (Nn from to +65,536). 

1 .7.4.2 Reverse Carry Modifier 

The address modification is performed by propagating the carry in the reverse direction, 
i.e., from the MSB to the LSB. If the (Rn)+Nn addressing mode is used with this address 
modifier, and Nn contains the value 2 K1 (a power of two), then postincrementing by Nn is 
equivalent to bit-reversing the K LSBs of Rn, incrementing Rn by 1, and bit-reversing the 
K LSBs of Rn again. This address modification is useful for 2 K point FFT addressing. The 
range of values for Nn is to +32,767 which allows bit-reversed addressing for FFTs up 
to 65,536 points. 

As an example, consider a 1 024 point FFT with real and imaginary data stored in memory. 
Then Nn would contain the value 51 2 and postincrementing by +N would generate the ad- 
dress sequence 0, 512, 256, 768, 128, 640, ... This is the scrambled FFT data order for 
sequential frequency points from to 2n. For proper operation, the reverse carry modifier 
restricts the base address of the bit reversed data buffer to an integer multiple of 2 K , such 
as 1024, 2048, 3072, etc. The use of addressing modes other than postincrement by Nn 
is possible but may not provide a useful result. 
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1.7.4.3 Modulo Modifier 

The modulo arithmetic unit can update one address register, Rn, during one instruction 
cycle and is capable of performing linear, reverse carry, and modulo arithmetic. The con- 
tents of the selected modifier register specifies the type of arithmetic required in an ad- 
dress register update calculation. There is no modulo capability for an R3 update for dual 
reads. 
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2.1 INTRODUCTION 

The DSP56166 pinout is shown in Figure 2-1 . The input and output signals on the chip 
are organized into the 13 functional groups shown in Table 2-1 . Figure 2-2 illustrates the 
relative timing for the bus signals. See the timing descriptions in the technical data sheet 
for more information. 

Table 2-1 Functional Group Pin Allocations 
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Functional Group 


Number of Pins 


Address and Data Buses 


32 


Bus Control 


10 


Interrupt and Mode Control 
Clock and PLL 


4 
3 


Host Interface or PIO 


15 


Timer Interface or PIO 


2 


SSI Interfaces or PIO 


8 


On-chip CODEC 
On-chip emulation (OnCE) 
Power (Vdd) 
Ground (Vss) 
APower (Vdda) 
AGround (Vssa) 


7 

4 

10 
15 
1 
1 


Total 


112 



2.2 ADDRESS AND DATA BUS (32 PINS) 

A0-A1 5 (Address Bus) — three state, active high outputs. A0-A1 5 change in to, and 
specify the address for external program and data memory accesses. If there 
is no external bus activity, A0-A1 5 remain at their previous values. A0-A15 are 
three-stated during hardware reset. 

D0-D15 (Data Bus) — three state, active high, bidirectional input/outputs. Read 
data is sampled in by the trailing edge of t2, while write data output is enabled 
by the leading edge of t2 and three-stated at the leading edge of to. If there is 
no extemalbus activity, D0-D1 5 are three-stated. D0-D1 5 are also three-stated 
during hardware reset. 

2.3 BUS CONTROL (1 PINS) 

PS/DS (Program/Data Memory Select) — three state active low output. This output 
is asserted only when external data memory is referenced. PS/DS timing is the 
same as the A0-A1 5 address lines. PS/DS is high for program memory access 
and is low for data memory access. If the external bus is not used during an 
instruction cycle (to, t1 , t2, t3), PS/DS goes high in to. PS/DS is in the high im- 
pedance state during hardware reset. 
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Interrupt 

and 

Mode 

Control 



MODA /IRQA - 

MODB /IRQB - 

MOD C/IRQC - 

RESET- 



r EXTAL— 

Clock CLKO^" 

and SXFC- 

PLL VddS~ 

GNDS- 



L 



A0-A15* 



External 
Bus 

56 pins 
(42 function, 
5Vdd, 9Vss) 



BS«- 
PS/DS^- 



PEREN<~ 

WR<- 

RD<- 

R/W«- 

TA- 



BR^- 
BGe- 
BB<- 
Vdd Control _ 
I— Vss Control _ 



.r 



r> h- ' DSI/ OS0<- 

un-cnip DSCK/OS1^- 

Emulation DSO«- 

L_ DR- 

QuietVdd- 
Vss- 



D0-D15«— 

Vdd Add/Data ±- 

Vss Add/Data — *- 



PB0-PB7 

PB8 

PB9 

PB10 

PB11 
PB12 
PB13 
PB14 



DSP56166 



PORTA 



PCO 
PC1 
PC2 

PC4 

PC5 
PC6 
PC7 

PC9 

PC10 
PC11 



112 pins 
(85 functional pins, 
15 ground pins, 
10 power pins, 
1 Aground pin, 
1 Apower pin) 



H0-H7 

HAO 
HA1 
HA2 

HR/W 
HEN 
HREQ 
HACK 

Vdd Port B 
Vss Port B 

STDO 
SRDO 
SCKO 



Host 
Parallel 
Interface 



-> SFSO 



-> STD1 

- SRD1 
-> SCK1 

-» SFS1 

- TIN 
-> TOUT 



Two 

Serial 

Interfaces 



"1 Timer 



Mic 
Aux 



-> SPKP 
-* SPKM 



On-chip 
Codec 



Vrad 

Vrda 

Vdiv 

VddA 

VssA 

Vdd port C 

Vss Port C 



Figure 2-1. DSP56166 Pinout 
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PEREN 



R/W 



WR 



RD 



BS 



(Peripheral Enable) — three state active low output. This output is asserted 
only when external peripheral space of the data memory is referenced (any ad- 
dress between X:$FF00 and X:$FF7F). PEREN timing is th e same as the A0- 
A15 address lines; it is asserted and deasserted during to. PEREN is high for 
any program memory access and for data memory access not in the space 
X:$FF00 - X:$FF7F. PEREN is in the high impedance state during hardware re- 
set. 

(Read/Write) — three state, active low output. Timing is the same as the ad- 
dress lines, providing an "early write" signal. R/W (which changes to tO) is high 
for a read access and is low for a write access. If the external bus is not used 
during an instruction cycle (to, t1 , t2, and t3), R/W goes high in to. R/W is three- 
stated during hardware reset. 

(Write Enable) — three state, active low output. This output is asserted dur- 
ing external memory write cycles. When WR is asserted low in t1 , the data bus 
pins D0-D1 5 become outputs and the DSP puts data on the bus during the lead- 
ing edge of t2. When WR is deasserted high in t3, the external data has been 
latched inside the external device. When WR is asserted, it qualifies the A0- 
A1 5, PS/DS pins. WR is three-stated during hardware reset or when the DSP is 
not bus master. WR can be connected directly to the WE pin of a static RAM. 

(Read Enable) — three state, active low output. This output is asserted dur- 
ing external memory read cycles. When RD is asserted low late tO/early t1 , the 
data bus pins D0-D15 become inputs and an external device is enabled onto 
the data bus. When RD is deasserted high in t3, the external data has been 
latched inside the DSP. When RD is asserted, it qualifies the A0-A15 and 
PS/DS pins. RD is three-stated during hardware reset or when the DSP is not 
bus master. RD can be connected directly to the OE pin of a static RAM or ROM 

(Bus Strobe) — active low output. This output is asserted low at the start of 
a bus cycle (during tO) and deasserted high at the end of the bus cycle (during 
t2). This pin provides an "early bus start" signal which can be used as an ad- 
dress latch and as an "early bus end" signal which can be used by an external 
bus controller. BS is three-stated during hardware reset. 
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CLKO 

BS 

A0-A15 

PS/DS 

R/W 
WR 
RD 

D0-D15 

CLKO 

BS 

PS/DS 
A0-A15 

R/W 
WR 




Bus Operation (Read-Write- OWT) 

TO T1 T2 Tw T2 Tw T2 Tw T2 T3 TO T1 T2 Tw T2 Tw T2 Tw T2 T3 TO T 

n 1 




I 



RD ~\_ 

D0-D15 - 



/ patst in 



X 



\ 



-H^ Data 



out 



Bus Operation (Read-Write- 3WT) 



Figure 2-2 Bus Operations 
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TA (Transfer Acknowledge) — active low input. If there is no external bus ac- 

tivity, the TA input is ignored by the DSP. When there is external bus cycle ac- 
tivity, TA can be used to insert wait states in the external bus cycle. TA is 
sampled on the leading edge of the clock. Any number of wait states from 1 to 
infinity may be inserted by using TA. If TA is sampled high on the leading edge 
of the clock beginning the bus cycle, the bus cycle will end 2T after TA has been 
sampled low on a leading edge of the clock; if the Bus Control Register (BCR) 
value does not program more wait states. The number of wait states is deter- 
mined by the TA input or by the BCR, whichever is longer. TA is still sampled 
during the leading edge of the clock when wait states are controlled by the BCR 
value. In that case, TA will have to be sampled low during the leading edge of 
the last period of the bus cycle programmed by the BCR (2T before the end of 
the bus cycle programmed by the BCR) in order not to add any wait states. TA 
should always be deasserted high during t3 to be sampled high by the leading 
edge of to. If TA is sampled low (asserted) at the leading edge of the to begin- 
ning the bus cycle, and if no wait states are specified in the BCR register, zero 
wait states will be inserted in the external bus cycle regardless the status of TA 
during the leading edge of t2. 



a 



CLKO 



TA 



CLKO 



TA 



BS 



TO T1 T2 T3 TO T1 T2 Tw T2 T3 TO T1 T2 T3 TO T1 T2 Tw T2 Tw T2 T3 



BS ~^/- 
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uzx 



\ 



Lr 



TO T1 T2 Tw T2 Tw T2 Tw T2 T3 TO T1 T2 Tw T2 Tw T2 T3 TO T1 T2 




Figure 2-3 TA Controlled Accesses 
BR (Bus Request) — - active low output when in the master mode, active low 

input when in the slave mode. After power-on reset, this pin is an input (slave 
mode). In this mode, BR allows another device such as a processor or DMA 
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controller to become master of the DSP external data bus D0-D15 and the ex- 
ternal address bus A0-A15. The DSP asserts BG a few T states after the BR 
input is asserted. The DSP bus controller will release control of the external 
data bus D0-D15, address bus A0-A15 and bus control pins PEREN, PS/ DS, 
RD, WR, and R/W at the earliest time possible consistent with proper synch ro- 
nization. These pins will then be placed in the high impedance state and the BB 
pin will be deasserted. The DSP will continue executing instructions only if in- 
ternal program and data memory resources are being accessed. If the DSP re- 
quests the external bus while the BR input pin is asserted, the DSP bus 
controller inserts wait states until the external bus becomes available (BR and 
BB deasserted). Note that interrupts are not serviced when a DSP instruction 
is waiting for the bus controller. Note also that BR is prevented from interrupting 
the execution of a read/ modify/ write instruction. 

If the master bit in the OMR register is set, this pin becomes an output (Master 
Mode). In this mode, the DSP is not the external bus master and has to assert 
BR to request the bus mastership. The DSP bus controller will insert wait states 
until BG input is asserted and will then begin normal bus accesses after the ris- 
ing of the clock which sampled BB high. The BR output signal will remain as- 
serted until the DSP no longer needs the bus. In this mode, the Request Hold 
bit (RH) of the BCR allows BR to be asserted under software control. 

During external accesses caused by an instruction executed out of external 
program memory, BR remains asserted low for consecutive external X memory 
accesses and continues toggling for consecutive external P memory accesses 
unless the Request Hold bit (RH) is set inside the BCR. 

In the master mode, BR can also be used for non arbitration purposes: if BG is 
always asserted, BR is asserted in to of every external bus access. It can then 
be used as a chip select to turn an external memory device off and on between 
internal and external bus accesses. BR timing is, in that case, similar to A0-A15, 
R/W, and PS/DS; it is asserted and deasserted during to. 

BG (Bus Grant) — active Sow Input whan in the master mode, active iow out- 

put when in the siave mode. This pin is an output after power on reset if the 
slave is selected and is asserted to acknowledge an external bus request. It in- 
dicates that the DSP will release control of the external address bus A0-A15, 
data bus D0-D15, and bus control pins when BB is deasserted. The BG output 
is asserted in response to a BR input. When the BG output is asserted and BB 
is deasserted, the external address bus A0-A1 5, data bus D0-D1 5 and bus con- 






INTERRUPT AND MODE CONTROL (4 PINS) 



trol pins are in the high impedance state. BG assertion may occur in the middle 
of an instruction which requires more than one external bus cycle for execution. 
Note that BG assertion will not occur during indivisible read-modify-write in- 
structions (BFSET,_BFCLR, BFCHG). When BR is deasserted and BB pin is 
sampled high then BG is deasserted and the DSP regains control of the exter- 
nal address bus, data bus, and bus control pins. 

This pin becomes an input if the master bit in the OMR register is set (Master 
Mode). It is asserted by an external processor when the DSP may become the 
bus master. The DSP can start normal external memory access after the BB pin 
has been deasserted by the previous bus master. When BG is deasserted, the 
DSP will release the bus as soon as the current transfer is completed. The state 
of BG may be tested by testing the BS bit in the Bus Control Register. 

BG is ignored during hardware reset. 

BB (Bus Busy) — active low input when not a bus master, active low output 

when a bus master. This pin is asserted by the DSP when it becomes the bus 
master and it performs an external access. It is deasserted when the DSP re- 
leases bus mastership. BB becomes an input when the DSP is no longer the 
bus master. 

2.4 INTERRUPT AND MODE CONTROL (4 PINS) 




MODA/IRQA (Mode Select A/External Interrupt Request A) — This input has two func- 
tions: (1) to select the initial chip operating mode and (2), after synchronization, 
to allow an external device to request a DSP interrupt. MODA is read and inter- 
nally latched in the DSP when the processor exits the reset state. MODA and 
MODB select the initial chip operating mode. Several clock cycles after leaving 
the reset state, the MODA pin changes to external interrupt request IRQA. The 
chip operating mode can be changed by software after reset. The IRQA input 
is a synchronized external interrupt request which indicates that an external de- 
vice is requesting service. It may be programmed to be level sensitive or neg- 
ative edge triggered. If level sensitive triggering is selected, an external pull up 
resistor is required for wired-OR operation. If the processor is in the stop state 
and IRQA is asserted, the processor will exit the stop state. 



MODB/IRQB (Mode Select B/External Interrupt Request B) — This input has two func- 
tions: (1) to select the initial chip operating mode and (2), after internal synchro- 
nization, to allow an external device to request a DSP interrupt. MODB is read 
and internally latched in the DSP when the processor exits the reset state. 
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POWER, GROUND, AND CLOCK (30 PINS) 



MODA and MODB select the initial chip operating mode. Several clock cycles 
after leaving the reset state, the MODB pin changes to external interrupt re- 
quest IRQB. After reset, the chip operating mode can be changed by software. 
The IRQB input is an external interrupt request which indicates that an external 
device is requesting service. It may be programmed to be level sensitive or neg- 
ative edge triggered. If level sensitive triggering is selected, an external pull up 
resistor is required for wired-OR operation. 



MODC/IRQC (Mode Select C/Exfernal Interrupt Request C) — This input has two func- 
tions: (1) to select the initial bus operating mode and (2), after internal synchro- 
nization, to allow an external device to request a DSP interrupt. MODC is read 
and internally latched in the DSP when the processor exits the reset state. 
When tied high, the external bus is programmed in the master mode (BR output 
and BG input) and when tied low, the bus is programmed in the slave mode (BR 
input and BG output). After reset, the bus operating mode can be changed by 
software writing the MC bit of the OMR register. Several clock cycles after leav- 
ing the reset state, the MODC pin changes to the external interrupt request 
IRQC. The IRQC input is an external interrupt request which indicates that an 
external device is requesting service. It may be programmed to be level sensi- 
tive or negative edge triggered. If level sensitive triggering is selected, an exter- 
nal pull up resistor is required for wired-OR operation. 



RESET (Reset) — This input is a direct hardware reset on the processor. When RESET 
is asserted low, the DSP is initialized and placed in the reset state. A Schmitt 
trigger input is used for noise immunity. When the RESET pin is deasserted, 
the initial chip operating mode is latched from the MODA and MODB pins. The 
internal reset signal should be deasserted synchronous with the internal clocks. 

2.5 POWER, GROUND, AND CLOCK (30 PINS) 
VCC (8) (Power) — power pins. 

VSS (15) (Ground) — ground pins. 

VDDS (Synthesizer Power) — This pin supplies a quiet power source to the VCO to 
provide greater frequency stability. 

GNDS (Synthesizer Ground) — This pin supplies a quiet ground to the VCO to pro- 
vide greater frequency stability. 

EXTAL (External Clock/Crystal input) — - This input should be connected to an exter- 
nal clock or to an external oscillator. A sine wave with a minimum swing of 1 Vpp 
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can be applied to this pin. After being squared, the input clock can be selected 
to directly provide the clock to the DSP core. In that case, it is divided by two 
into the core to produce a four phase instruction cycle clock, the minimum in- 
struction time being two input clock periods.This input clock can also be select- 
ed as input clock for the on-chip codec and the on-chip PLL. 

CLKO (Clock Output) — This pin outputs a buffered clock signal. By programming 
two bits (CS1-CS0) inside the PLL control register PLCR, the user can select 
between outputting a squared version of the signal applied to EXTAL, a 
squared version of the signal applied to EXTAL divided by 2, and a delayed ver- 
sion of the DSP core master clock. The clock frequency on this pin can be dis- 
abled by setting the Clockout Disable bit (CD; bit 7) of the Operating Mode 
Register (OMR). 

SXFC (External Filter Capacitor) — This pin is used to add an external capacitor to 
the filter circuit of the phase locked loop. The capacitor should be connected 
between SXFC and VDDS. 

VDDA (Power Supply Input) — This pin is the positive analog supply input. It should 
be connected to Vdd when the codec is not used. 

VSSA (Analog Ground) — This pin is the analog ground return. It should be connect- 
ed to Vss when the codec is not used. 

2.6 HOST INTERFACE (15 PINS) 

H0-H7 (Host Data Bus) — This bidirectional data bus is used to transfer data between 
the host processor and the DSP. This bus is an input unless enabled by a host 
processor read. H0-H7 may be programmed as general purpose parallel I/O 
pins called PB0-PB7 when the Host Interface (HI) is not being used. 

HAO-2 (Host Address 0-2) — These inputs provide the address selection for each HI 
register and are stable when HEN is asserted. HA0-HA2 may be programmed 
as general purpose I/O pins called PB8-PB10 when the HI is not being used. 

HR/W (Host Read/Write) — This input selects the direction of data transfer for each 
host processor access. If HR/W is high and HEN is asserted, H0-H7 are outputs 
and DSP data is transferred to the host processor. If HR/W is low and HEN is 
asserted, H0-H7 are inputs and host data is transferred to the DSP. HR/W is 
stable when HEN is asserted. HR/W may be programmed as a general purpose 
I/O pin called PB1 1 when the HI is not being used. 
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HEN (Host Enable) — This inputenables a data transfer on the host data bus. When 
HEN is asserted and HR/W is high, H0-H7 becomes an output and DSP data 
may be latched by the host processor. When HEN is asserted and HR/W is low, 
H0-H7 is an input and host data is latched inside the DSP when HEN is deas- 
serted. Normally a chip select signal derived from host address decoding and 
an enable clock is connected to the Host Enable. HEN may be programmed as 
a general purpose I/O pin called PB1 2 when the HI is not being used. 



HREQ (Host Request) — This open-drain output signal is used by the HI to request 
service from the host processor. HREQ may be connected to an interrupt re- 
quest pin of a host processor, a transfer request of a DMA controller, or a con- 
trol input of external circuitry. HREQ is asserted when an enabled request 
occurs in the HI. HREQ is deasserted when the enabled request is cleared or 
masked, DMA HACK is asserted, or the DSP is reset. HREQ may be pro- 
grammed as a general purpose I/O pin (not open-drain) called PB13 when the 
HI is not being used. 



HACK (Host Acknowledge) — This input has two functions: (1 ) to provide a Host Ac- 
knowledge signal for DMA transfers or (2) to control handshaking and to pro- 
vide a Host Interrupt Acknowledge compatible with MC68000 family 
processors. If programmed as a Host Acknowledge signal, HACK may be used 
as a data strobe for HI DMA data t ransfers. If programmed as an MC68000 
Host Interrupt Acknowledge, HACK is used to enable the HI Interrupt Vector 
Register (IVR) onto the Host Data Bus H0-H7 if the Host Request HREQ output 
is asserted. I n this c ase, all other HI control pins are ignored and the HI state is 
not affected. HACK may be programmed as a general purpose I/O pin called 
PB14 when the HI is not being used. 

2.7 16-BITTIMER(2PiNS) 

TIN (Timer Input) — This input receives external pulses to be counted by the on- 

chip 16-bit timer when external clocking is selected. The pulses are internally 
synchronized to the DSP core internal clock. TIN may be programmed as a 
general purpose I/O pin called PC1 when the external event function is not be- 
ing used. 

TOUT (Timer Output) — This output generates pulses, toggles on a timer overflow 
event, or toggles on a compare event. TOUT may be programmed as a general 
purpose I/O pin called PC1 1 when disabled by the timer out enable bits (T02- 
TOO). 
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2.8 REDUCED SYNCHRONOUS SERIAL INTERFACES (RSSIO AND RSSI1 ) 
AND PORT C (8 PINS) 

STDO/PCO (RSSIO Transmit Data) — This output pin transmits serial data from the 
RSSIO Transmit Shift Register. STDO may be programmed as a general pur- 
pose I/O pin called PCO when the RSSIO STDO function is not being used. 

SRD0/PC1 (RSSIO Receive Data) — This input pin receives serial data and transfers 
the data to the RSSIO Receive Shift Register. SRDO may be programmed as a 
general purpose I/O pin called PC1 when the RSSIO SRDO function is not being 
used. 

SCK0/PC2 (RSSIO Serial Clock) — This bidirectional pin provides the serial bit rate 
clock for the RSSIO interface. The clock signal can be continuous or gated and 
is used by both the transmitter and receiver. SCKO may be programmed as a 
general purpose I/O pin called PC2 when the RSSIO interface is not being used. 

SFS0/PC4 (Serial Frame Sync 0) — This bidirectional pin is used by the RSSIO serial 
interface as frame sync I/O or flag I/O. The SFSO is used by both the transmitter 
and receiver to synchronize data transfer and can be an input or an output. 
SFSO may be programmed as a general purpose I/O pin called PC4 when the 
RSSIO is not using this pin. 



STD1/PC5 (RSSI1 Transmit Data) — This output pin transmits serial data from the 
RSSI1 Transmit Shift Register. STD1 may be programmed as a general pur- 
pose I/O pin called PC5 when the RSSI1 STD1 function is not being used. 

SRD1/PC6 (RSSI1 Receive Data) — This input pin receives serial data and transfers 
the data to the RSSI1 Receive Shift Register. SRD1 may be programmed as a 
general purpose I/O pin called PC6 when the RSSI1 SRD function is not being 
used. 

SCK1/PC7 (RSSI1 Serial Clock) — This bidirectional pin provides the serial bit rate 
clock for the RSSI1 interface. The clock signal can be continuous or gated and 
is used by both the transmitter and receiver. SCK1 may be programmed as a 
general purpose I/O pin called PC7 when the RSSI1 interface is not being used. 

SFS1/PC9 (Serial Frame Sync 1) — This bidirectional pin is used by the RSSI1 serial 
interface as frame sync I/O or flag I/O. The SFS1 is used by both the transmitter 
and receiver to synchronize data transfer and can be an input or an output. 
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SFS1 may be programmed as a general purpose I/O pin called PC9 when the 
RSSI1 is not using this pin. 

2.9 ON-CHIP EMULATION (4 PINS) 

DSI/OSO (Debug Serial Input/Chip Status 0) — The DSI/OSO pin, when an input, is 
the pin through which serial data or commands are provided to the OnCE con- 
troller. The data received on the DSI pin will be recognized only when the DSP 
has entered the debug mode of operation. Data must have valid TTL logic lev- 
els before the serial clock falling edge. Data is always shifted into the OnCE se- 
rial port most significant bit (MSB) first. When the DSP is not in the debug mode, 
the DSI/OSO pin provides information about the chip status if it is an output and 
used in conjunction with the OS1 pin. 



DSCK/OS1 (Debug Serial Clock/Chip Status 1) — The DSCK/OS1 pin, when an in- 
put, is the pin through which the serial clock is supplied to the OnCE. The serial 
clock provides pulses required to shift data into and out of the OnCE serial port. 
Data is clocked into the OnCE on the falling edge and is clocked out of the 
On CE seri al port on the rising edge. When the DSP is not in the debug mode, 
the DSCK/OS1 pin provides information about the chip status if it is an output 
and used in conjunction with the OS0 pin. 

DSO (Debug Serial Output) — The debug serial output provides the data contained 
in one of the OnCE controller registers as specified by the last command re- 
ceived from the command controller. When idle, this pin is high. When the re- 
quested data is available, the DSO line will be asserted (negative true logic) for 
four T cycles (one instruction cycle) to indicate that the serial shift register is 
ready to receive clocks in order to deliver the data . When the chip enters the 
debug mode due to an external debug request (DR), an internal software debug 
request (DEBUG), a hardware breakpoint occurrence, or a trace/step occur- 
rence, this line will be asserted for three T cycles to indicate that the chip has 
entered the debug mode and is waiting for commands. Data is always shifted 
out the OnCE serial port most significant bit (MSB) first. 

DR (Debug Request Input) — The debug request input provides a means of en- 

tering the debug mode of operation. This pin, when asserted (negative true log- 
ic), will cause the DSP to finish the instruction being executed, enter the debug 
mode, and wait for commands to be entered from the debug serial input line. 
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2.10 ON-CHIP CODEC (7 PINS) 

AUX (Auxiliary Input) — This pin is selected as the analog input to the A/D convert- 
er when the INS bit is set in the codec control register COCR.This pin should 
be left floating when the codec is not used. 

MIC (Microphone Input) — This pin is selected as the analog input to the A/D con- 

verter when the INS bit is cleared in the codec control register COCR.This pin 
should be left floating when the codec is not used. 

SPKP (Speaker Positive Output) — This pin is the positive analog output from the 
on-chip D/A converter.This pin should be left floating when the codec is not 
used. 

SPKM (Speaker Negative Output) — This pin is the negative analog output from the 
on-chip D/A converter.This pin should be left floating when the codec is not 
used. 

VRAD (Voltage Reference Output for the A/D) — This pin is the output of the op- 
amp buffer in the A/D sections reference voltage generator. It has a value of 
(2/5) VDDA. This voltage is used as the analog ground internal to the block.This 
pin should always be connected to ground through two capacitors, even when 
the codec is not used. 

VRDA (Voltage Reference Output for the D/A) — This pin is the output of the op- 
amp buffer in the D/A sections reference voltage generator. It has a value of 
(2/5) VDDA. This voltage is used as the analog ground internal to the block.This 
pin should always be connected to the ground through two capacitors, even 
when the codec is not used. 

VDIV (Voltage Division Output) — This pin is the input to the op-amp buffer in the 
reference voltage generator. It is connected to a resistor divider network locat- 
ed within the codec block which provides a voltage equal to 2/5 VDDA.This pin 
should be left floating when the codec is not used. 



^ 



MOTOROLA 



DSP56166 PIN DESCRIPTIONS 



2-15 



ON-CHIP CODEC (7 PINS) 



2*16 DSP561 66 PIN DESCRIPTIONS MOTOROLA 






SECTION 3 

OPERATING MODES 
AND MEMORY CONFIGURATION 



4 




MOTOROLA OPERATING MODES AMD MEMORY CONFIGURATION 3- 1 



sicw 



$M§&0%± ^-^^W^Modp: i Y. Y:- Y- • YY YvY : Y < _♦ '"; .+.-+• • 

;$P-i^^ :;••,.;• ii ; ^YY Y< : : Y' Y-- * Y-j : .r * ^ 



3-10 

3-10 

3-T1 

3,12 

3-12 

3r12 ; 

3-13 

3-13 



3i2dl»ERAflNG MOOES AN 



i 



INTRODUCTION 



3.1 INTRODUCTION 

The DSP56166 is available in two different on-chip memory configurations: a RAM based 
part and a ROM based part. This section describes in detail the on-chip memories and the 
operating modes of the two versions. 

3.2 DSP561 66 RAM BASED DESCRIPTION 

The RAM based DSP561 66 uses RAM for the on-chip Program Memory and for the on- 
chip Data Memory. The two independent memory spaces, X data and program, are 
shown in Figure 3-2. The memory spaces are configured by control bits in the operating 
mode register (OMR). The operating mode control bits (MA and MB) in the OMR control 
the program memory map and select the reset vector address. Both the program and data 
memories can be expanded off-chip. 

3.2.1 X Data Memory 

The DSP561 66 has 4096 words of on-chip data RAM: 1 28 data memory locations are re- 
served for on-chip peripheral registers (X:$FF80-FFFF) and 128 additional locations 
(X:$FF00-FF7F) are reserved for off-chip peripheral accesses. The external bus access 
time on this external peripheral space is controlled by 5 bits of an additional bus control 
register, BCR2, located at X:$FFDA (see Figure 3-1). Between and 31 software pro- 
grammable wait states can be generated. A special pin, PEREN, is asserted low during 
accesses to the memory mapped external peripheral registers. 
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Figure 3-1 External Peripheral Bus Control Register (BCR2) 

The X memory may be expanded off-chip for a total of 65,280 (65,536-256) addressable 
locations.The external data memory bus access time is controlled by 5 bits of an addition- 
al bus control register (BCR, located at X:$FFDE). This register is described in Figure 3-1 . 
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Figure 3-2 DSP561 66 RAM based Memory Map 

The External X memory bit (EXT bit 3) of the OMR determines the mapping of the X mem- 
ory as shown in Figure 3-2. Setting this bit completely disables the on-chip data memory 
and enables the full 64 K external memory map. This bit is ignored by the fast interrupt 
process so that the on-chip peripheral space and off-chip peripheral space can be access- 
ed during fast interrupts. During long interrupts, this bit, if set before the interrupt, can be 
cleared by the user program inside the interrupt routine in order to access the on-chip pe- 
ripheral space and the on-chip memory; it can be set again before the RTI instruction. 
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When the EX bit is set, external data memory access is only controlled by the BCR except 
during fast interrupts, where BCR2 controls external accesses to the off-chip peripheral 
space. 

3.2.2 Program Memory 

The RAM based DSP561 66 has 2048 words of on-chip program RAM. The first 1 28 loca- 
tions of program memory are reserved for interrupt vectors. The program memory may be 
expanded off-chip for a total of 65,536 addressable locations.The external data memory 
bus access time is controlled by 5 bits of the bus control register BCR located at X:$FFDE. 
This register is described in Figure 3-1 . 

3.2.3 Bootstrap ROM 

The Bootstrap ROM is a 64 location by 16-bit factory programmed ROM which is used 
only in the bootstrap modes, Operating Modes and 1 , during which the on-chip program 
RAM is defined as write-only. The bootstrap ROM is not accessible by the user and is dis- 
abled in normal operating modes. Refer to APPENDIX A BOOTSTRAP OPERATING 
MODE — OPERATING MODE or 1 for a full description of the bootstrap feature of the 
DSP56166. 

The bootstrap program can load from any one of three different sources. Selection of 
which one of the three is made by reading the mode pins and, if necessary, bit-15 of 
P:$C000 from the external data bus. 

If MB:MA = 00 (Mode 0) then the bootstrap program will load from an external byte-wide 
memory. This bootstrap program will load 4,096 bytes from the external P: memory space 
beginning at location P:$C000 (bits 0-7). These will be packed into 2,048 16-bit words and 
stored in contiguous internal program RAM memory locations starting at P:$0000. The 
byte-wide data will be packed into the 1 6-bit memory least significant byte first. 

If MB:MA = 01 (Mode 1), the bootstrap program will read bit-15 of P:$C000 from the ex- 
ternal data bus. If bit-1 5 = 0, the bootstrap program will load 4,096 bytes through the host 
port (the host processor can terminate down-loading early by setting HF0=0). If bit-15 = 
1 , the bootstrap program will load through RSSI0. Data is packed into program RAM least 
significant byte of P:$0000 first. 

3.2.4 RAM Based DSP56166 Operating Modes 

The DSP operating modes determine the memory maps for program and data memories 
and the start-up procedure when the DSP leaves the reset state. The MODA, MODB, and 
MODC pins are sampled as the DSP leaves the reset state and the initial operating mode 
of the DSP is set accordingly. After the reset state is exited, the MODA and MODB pins 
become general-purpose interrupt pins, IRQA and IRQB. One of three initial operating 
modes is selected: single chip, normal expanded, or development, chip operating modes 
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Table 3-1 Operating Mode Summary 
Program RAM Part 



Operating 
Mode 


M 
B 


M 
A 


Description 


Special 
Bootstrap 1 








Bootstrap from an external 
byte-wide memory located 
at P:$C000. Reset at P:$0000 


Special 
Bootstrap 2 





1 


Bootstrap from the Host port 
(P:$C000bit15=0)orRSSI0 
(P:$C000 bit 15=0) 
Reset at P:$Q000 


Normal 
Expanded 


1 





Internal PRAM enabled; 
External reset at P:$E000 


Development 
Expanded 


1 


1 


Internal program memory 
disabled; External reset at 
P:$0000. 



can be changed by writing the operating mode bits (MB, MA) in the OMR. Changing op- 
erating modes does not reset the DSP. It is desirable to disable interrupts immediately 
before changing the OMR to prevent an interrupt from going to the wrong memory loca- 
tion. Also, one no-operation (NOP) instruction should be included after changing the OMR 
to allow for remapping to occur. 

3.2.4.1 Bootstrap Mode (Mode 0). 

Mode is one of two single-chip modes which have all internal program memories en- 
abled (see Figure 3-2). This mode can be entered by either grounding both mode pins and 
resetting the chip or by writing to the OMR and changing the MA and MB bits. When the 
operating mode is first changed to Mode 0, the DSP56166 executes a bootstrap program 
which loads program memory from a byte wide memory located at P:$G000 (see Table 3- 
1). Section 3.2.5.2 describes the bootstrap operation. The memory maps for Mode and 
Mode 1 are identical. The only difference between the two modes is the location of the 
reset vector in program memory. The reset vector location in Mode is P:$0000. The re- 
set vector location in Mode 2 is P:$E000 (external memory). 

3.2.4.2 Bootstrap Mode (Mode 1). 

Mode 1 is one of two single-chip modes which have all internal program and data RAM 
memories enabled (see Figure 3-2). This mode can be entered by either grounding the 
MB pin and pulling the MA pin high or by writing to the OMR and changing the MA and 
MB bits (see Table 3-1). When the operating mode is first changed to Mode 1, the 
DSP56166 executes a bootstrap program which loads program memory from either the 
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host port or the RSSIO depending on whether bit 1 5 of location P:C000 is a zero (host port) 
or a one (RSSIO). Section 3.2.5.2 describes the bootstrap operation. The memory maps 
for Mode and Mode 1 are identical. The memory maps for Mode 1 and Mode 2 are very 
similar. The memory map difference between Mode and Mode 2 is the location of the 
reset vector in program memory. The reset vector location in Mode is P:$0000. The re- 
set vector location in Mode 2 is P:$E000. 

3.2.4.3 Normal Expanded Mode (Mode 2). 

The normal expanded mode (Mode 2) has the same memory map as Mode and Mode 
1 (see Figure 3-2). The difference is that entering Mode 2 does not cause the bootstrap 
program to be executed and the reset vectors to external program memory location 
P:$C000. This mode can be entered by either grounding the MA pin and pulling the MB 
pin high or by writing to the OMR and changing the MA and MB bits (see Table 3-1). 

3.2.4.4 Development Mode (Mode 3). 

The development mode is similar to the normal expanded mode except that internal pro- 
gram memory is disabled (see Figure 3-2). All references to program memory space are 
directed to external program memory, which is accessed on the external data bus. This 
mode can be entered by either pulling the MA and MB pins high or by writing to the OMR 
and changing the MA and MB bits (see Table 3-1). The reset vector location in Mode3 is 
external program memory location P:$0000. 

3.2.5 Bootstrap Mode 

The bootstrap feature consists of a special on-chip bootstrap ROM containing a bootstrap 
program and a bootstrap control logic. The bootstrap feature is only available on the pro- 
gram RAM part. It is not available on the program ROM part. Appendix A describes the 
contents of the boot ROM. 

3.2.5.1 Bootstrap ROM 

This 64-word on-chip ROM is factory programmed to perform the actual bootstrap opera- 
tion from the memory expansion port (Port A), from the Host Interface, or from the Re- 
duced Synchronous Serial Interface RSSIO. No access is provided to the bootstrap ROM 
other than through the bootstrap process. Control logic will disable the bootstrap ROM 
during normal operations. 

3.2.5.2 Bootstrap Control Logic 

The bootstrap mode control logic is activated when the DSP is placed in one of the boot- 
strap modes, Mode or Mode 1 . The control logic maps the bootstrap ROM into program 
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memory space until the bootstrap program changes operating modes when the bootstrap 
load is completed. 

When the DSP exits the reset state in Mode or 1 , the following actions occur: 

1 . The control logic maps the bootstrap ROM into the internal DSP program 
memory space starting at location P:$0000. All program fetches during 
the bootstrap operation are from the bootstrap ROM. 

2. The control logic forces the entire internal program RAM space to be 
write-only memory during the bootstrap loading process. All write 
operations during the bootstrap program execution are to the PRAM. 

3. Program execution begins at location $0000 in the bootstrap ROM. The 
bootstrap ROM program performs the load of the internal program RAM 
(PRAM) through either the memory expansion port from a byte-wide 
external memory, through the Host Interface, or through the Reduced 
Synchronous Serial Interface RSSIO. 

4. Upon completing the program RAM load, the bootstrap program 
terminates the bootstrap operation by entering Operating Mode 2 
(writing to the OMR) and by branching to the internal program RAM 
location P:$0000. During the execution of the branch to P:$0000, the 
bootstrap ROM is disabled and fetches from the PRAM are re-enabled. 

The bootstrap mode may also be selected by setting the OMR bits for Operating Mode 
or 1 . This initiates a timed operation to map the bootstrap ROM into the program address 
space after a delay to allow execution of a single instruction and a jump to P:$0000 to start 
executing the bootstrap program. This technique allows the user to reboot the internal 
PRAM (with a different program if desired). 

3.2.5.3 Bootstrap Program 

The bootstrap ROM contains the bootstrap firmware program that performs initial loading 
of the DSP's internal program RAM (see Appendix A for a listing of the bootstrap code). 
The program is written in DSP5616 core assembly language. It contains three separate 
methods of initializing the PRAM: loading from a byte-wide memory starting at location 
P:$C000, loading through the Host Interface, or loading through the Reduced Synchro- 
nous Serial Interface RSSIO. 

When Mode is selected, the external bus version of the bootstrap is executed. The data 
contents of the external byte-wide memory must be organized as shown in Table 3-2. 
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Table 3-2 Data Mapping for External Bus Bootstrap 



Address of External 
Byte-wide Memory 


Contents Loaded 
to Internal PRAM at: 


P:$C000 
P:$C001 

* 

* 
P:$CFFE 
P:$CFFF 


P:$0000 low byte 
P:$0000 high byte 

* 
P:$07FF low byte 
P:$07FF high byte 



m 



When Mode 1 is selected, the bootstrap is performed through the Host port or the RSSIO 
depending on the level of the most significant bit of P:$C000. 

If Bit 15 of P:$C000 is zero (a pull-down resistor can be used in some applications), the 
host port bootstrap is selected. Typically a host processor will be connected to the 16-bit 
DSP Host Interface and a host microprocessor will write the Host Interface registers TXH 
and TXL with the desired contents of PRAM from locations P:$0000 to P:$07FF. If less 
than 2048 words are to be loaded into the PRAM, the host programmer can terminate the 
bootstrap process by setting HF0=1 in the Host Interface. 

If bit 1 5 of P:$C000 is set (a pull-up resistor can be used in some applications), the boot- 
strap is performed through the Reduced Synchronous Serial Interface RSSIO. The boot- 
strap program sets up the RSSIO in 8 bit mode, external clock, and synchronous mode. 
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3.3 DSP561 66 ROM BASED DESCRIPTION 

The RAM DSP56166 uses a combination of RAM and ROM for the on-chip Program 
Memory and for the on-chip Data Memory. The two independent memory spaces, X 
data, and program, are shown in Figure 3-3. The memory spaces are configured by con- 
trol bits in the operating mode register (OMR). The operating mode control bits (MA and 
MB) in the OMR control the program memory map and select the reset vector address. 
Both the program and data memories can be expanded off-chip. 

3.3.1 X Data Memory 

DSP56166 has 4096 words of on-chip data RAM and 4096 words of on-chip data ROM. 
128 data memory locations are reserved for on-chip peripheral registers (X:$FF80-FFFF) 
and 128 additional locations (X:$FF00-FF7F) are reserved for off-chip peripheral access- 
es. The external bus access time on this external peripheral space is controlled by 5 bits 
of an additional bus control register BCR2 located at X:$FFDA. This register is described 
in Figure 3-1 . Between and 31 software programmable wait states can be generated. A 
special pin, PEREN, is asserted low during accesses to the memory mapped external pe- 
ripheral registers. The X memory may be expanded off-chip for a total of 65,280 (65,536- 
256) addressable locations. 

The External X memory bit (EXT bit-3) of the OMR determines the mapping of the X mem- 
ory as shown on Figure 3-3. Setting this bit completely disables the on-chip data memory 
and enables a full 64 K external memory map. This bit is ignored by the fast interrupt pro- 
cess so that the on-chip peripheral space and off-chip peripheral space can be accessed 
during fast interrupts. During long interrupts, this bit, if set before the interrupt, can be 
cleared by the user program inside the interrupt routine in order to access the on-chip pe- 
ripheral space and the on-chip memory; it can be set again before the RTI instruction. 

When the EX bit is set, the external access on the data memory is controlled by the BCR 
only. Except during fast interrupts, where BCR2 will control external accesses to the off- 
chip peripheral space. 

NOTICE 

The on-chip XROM on the ROM based part is only con- 
nected to the XAB1 address bus. Therefore, the data locat- 
ed in this ROM is only accessible by the first read during dual 
parallel read instructions. 

During development using the RAM based part, the data to be 
mapped into the on-chip XROM of the ROM based part 
should not be accessed with a second read during a dual 
parallel read instruction. 
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Figure 3-3 DSP56166 ROM Based Memory Map 
3.3.2 Program Memory 

DSP56166 has 8192 words of on-chip program ROM and 256 words of on-chip program 
RAM. Since the DSP5616 core specifies on-chip program memory by blocks of power of 
two words, there is a non-accessible hole in the program memory between addresses 
P:$20FF and P:$3FFF (P:8447-P:16383). 

External program memory will start at location P:$4000 (P:16384) for mode 0,1 and 2 like 
shown on Figure 3-3. 

When mode 3 is selected, the complete 64 K words of program memory are external. 
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Note: The last 128 locations of the on-chip program ROM are reserved and are not 
available for use (P:$2080-$20FF). 

3.3.3 ROM Based DSP56166 Operating Modes 

The DSP operating modes determine the memory maps for program and data memories 
and the start-up procedure when the DSP leaves the reset state. The MODA, MODB, and 
MODC pins are sampled as the DSP leaves the reset state and the initial operating mode 
of the DSP is set accordingly. After the reset state is exited, the MODA and MODB pins 
become general-purpose interrupt pins, IRQA, and IRQB. One of three initial operating 
modes is selected: single chip, normal expanded, or development. Chip operating modes 
can be changed by writing the operating mode bits (MB, MA) in the OMR. Changing op- 
erating modes does not reset the DSP. It is desirable to disable interrupts immediately 
before changing the OMR to prevent an interrupt from going to the wrong memory loca- 
tion. Also, one no-operation (NOP) instruction should be included after changing the OMR 
to allow for remapping to occur. 

Note: Since the on-chip X data ROM is connected to the XAB1 address bus, the data 
located in this ROM is only accessible by the first read during dual parallel read 
instructions. 

Table 3-3 DSP56166 ROM Based Operating Modes 



MB 


MA 


Chip Operating 
Mode 


Reset Vector 


Program Memory 
Configuration 








Single Chip 


Internal PRAM P:$0 


Internal Pmem Enabled 





1 


Single Chip 


Internal PROM P:$1 00 


Internal Pmem Enabled 


1 





Normal Expanded 


External Pmem P:$E000 


Internal Pmem Enabled 


1 


1 


Development 


External Pmem P:$0 


Internal Pmem Disabled 



3.3.3.1 Single-chip Mode (Mode 0). 

Mode is one of two single-chip modes which have all internal program and data memo- 
ries enabled (see Figure 3-3). This mode can be entered by either grounding both mode 
pins before resetting the chip or by writing to the OMR and changing the MA and MB bits. 
The memory maps for Mode and Mode 1 are identical. The only difference between the 
two modes is the location of the reset vector in program memory. The reset vector location 
in Mode is P:$0000 in the internal PRAM; whereas, the reset vector location in Mode 1 
is P:$100 in the internal PROM. 

3.3.3.2 Single-chip Mode (Mode 1). 

Mode 1 is one of two single-chip modes which have all internal program and data memo- 
ries enabled (see Figure 3-3). This mode can be entered by either grounding the MB pin 
and pulling the MA pin high before resetting the chip, or by writing to the OMR and chang- 
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ing the MA and MB bits. The memory maps for Mode and 1 are identical. The only dif- 
ference between these two modes is the reset vector location in program memory. The 
reset vector location in Mode is P:$0000 in internal PRAM; whereas, the reset vector 

location in Mode 1 is P:$100 in internal PROM. 

» 

3.3.3.3 Normal Expanded Mode (Mode 2). 

The normal expanded mode (Mode 2) can be entered by either pulling the MB pin high 
and grounding the MA pin before resetting the chip, or by writing to the OMR and changing 
the MA and MB bits. The memory maps for Mode 0,1 , and 2 are identical. The only differ- 
ence between the three modes is the location of the reset vector in program memory. The 
reset vector location in Mode 2 is located in the external program memory space at loca- 
tion P:$E000. 

3.3.3.4 Development Mode (Mode 3). 

The development mode is similar to the normal expanded mode except that internal pro- 
gram memory is disabled (see Figure 3-3). All references to program memory space are 
directed to external program memory, which is accessed on the external data bus. This 
mode can be entered by either pulling the MA and MB pins high or by writing to the OMR 
and changing the MA and MB bits (see Table 3-3). DSP561 66 ROM based chips with bad 
or obsolete internal program ROM code can be used with external program memory in the 
development mode. Reset vectors to external program memory location P:$0000. 
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4.1 INTRODUCTION 

The DSP561 66 provides 1 6 pins for an external address bus, 1 6 pins for an external data 
bus, and 1 pins for bus control. These pins are grouped to form the Port A bus interface. 
The DSP561 66 also provides 25 programmable I/O pins. These pins may be used as gen- 
eral purpose I/O pins or allocated to on-chip peripherals. Four digital on-chip peripherals 
are provided on the DSP56166: an 8 bit parallel Host MPU/DMA Interface, a 16-bit timer, 
and two Reduced Synchronous Serial Interfaces (RSSIO and RSSI1). These 25 pins are 
separate from the DSP56166 address and data buses and are grouped as two I/O ports 
(B and C). Figure 4-1 shows the I/O block diagram. 

Port B is a 15-bit I/O interface which may be used either as general purpose I/O pins or 
as Host MPU/DMA Interface pins. The Host MPU/DMA Interface provides a dedicated 8 L 
bit parallel port to a host microprocessor or DMA controller and can provide debugging 
facilities via host exceptions. 

Port C is a 1 0-bit I/O interface which may be used as general purpose I/O pins or as Timer 
and Serial Interface pins. The 16-bit timer can generate periodic interrupts based on a 
multiple of the internal or external clock. The two Reduced Synchronous Serial Interfaces, 
RSSIO and RSSI1 , are identical. They provide high speed synchronous serial data com- 
munication capability between the DSP56166 and other serial devices. Support for TDM 
network configurations allows communication among up to eight devices. 

These I/O interfaces are intended to minimize system chip count and "glue" logic in many 
DSP applications. Each I/O interface has its own control, status, and data registers and is 
treated as memory-mapped I/O by the DSP56166 (see Figure 4-2 and Figure 4-3). Each 
interface has several dedicated interrupt vector addresses and control bits to enable/dis- 
able interrupts. This minimizes the overhead associated with servicing the device since 
each interrupt source may have its own service routine. 

4.2 I/O PORT SET-UP AND PROGRAMMING 

Port A Bus Control Registers BCR and BCR2, located respectively at X:$FFDE and 
X:$FFDA, may be programmed to insert wait states in a bus cycle during external data 
and program memory accesses for BCR and during external peripheral accesses for 
BCR2. Five bits are available in each control register for each type of external memory 
access. Each 5 bit field can specify up to 31 wait states. On processor reset, these five 
bits for both P and X memories are preset to all ones so that 31 wait states are inserted 
allowing slow, inexpensive memory to be used immediately after reset. Ail other Port Con- 
trol Register bits are cleared on processor reset; i.e., reset sets the BCR to $03FF and 
BCR2to$001F. 
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Figure 4-1 DSP56166 Enput/Outpuf Block Diagram 
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Figure 4-2 DSP56166 I/O and On-Chip Peripheral Memory Map 
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Ports B and C pins may be programmed under software control as general purpose I/O 
pins or as dedicated on-chip peripheral pins. A Port Control Register is associated with 
each port which allows the port pins to be selected for one of these two functions. All port 
B pins are collectively configured as general purpose I/O pins if the corresponding Port 
Control Register bit is cleared and all are configured as HI pins if the corresponding Port 
Control Register bit is set. In contrast, each Port C pin is independently configured as a 
general purpose I/O pin if the corresponding Port Control Register bit is cleared and is 
configured as an RSSI pin or Timer pin if the corresponding Port Control Register bit is 
set. If a port pin is selected as a general purpose I/O pin, the direction of that pin is deter- 
mined by a corresponding control bit in the Port Data Direction Register. The port pin is 
configured as an input if the corresponding Data Direction Register bit is cleared and is 
configured as an output if the corresponding Data Direction Register bit is set. All Port 
Control Register bits and Data Direction Register bits are cleared on processor reset, con- 
figuring all port pins as general purpose input pins. If the port pin is selected as an on-chip 
peripheral pin, the corresponding data direction bit is ignored and the direction of that pin 
is determined by the operating mode of the on-chip peripheral. 

A port pin configured as a general purpose I/O pin is accessed through an associated Port 
Data Register B or C. Data written to the Port Data Register is stored in an output latch. 
If the port pin is configured as an output, the output latch data is driven out on the port pin. 
When the Port Data Register is read, the logic value on the output port pin is read. If the 
port pin is configured as an input, data written to the Port Data Register is still stored in 
the output latch but is not gated to the port pin. When the Port Data Register is read, the 
state of the port pin is read. That is, reading the port data register will reflect the state of 
the pins regardless of how they were configured. 

When a port pin is configured as a dedicated on-chip peripheral pin, the port data register 
will read the state of the input pin or output driver. 

4.2.1 Port Registers 

Ports A, B and C are controlled by programmable registers. Port A is controlled by the Bus 
Control Registers which control memory wait states. Ports B and C each have registers 
that select the peripheral to be available and control that peripheral. See Figure 4-3. 

4.2.1 .1 Bus Control Registers (BCR and BCR2) 

Port A Bus Control Registers (BCR and BCR2) are 16-bit read/write registers. They can 
be programmed to insert wait states in a bus cycle during external memory accesses and 
external peripheral accesses. 

In the BCR, 5 bit wait control fields specify between and 31 wait states for an external 
X memory and P memory access.Wait state fields are set to $1 F during hardware reset. 
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Bit 15 of the BCR, the Bus Request Hold bit, (RH), can be used for direct software control 
of the BR pin. When this bit is set, the BR pin is asserted even though the DSP does not 
need the bus. If RH is cleared, the BR pin will only be asserted if an external access is 
being attempted or pending. RH is cleared by hardware reset. 

Bit 14 of the BCR, the Bus State status bit (BS), is set if the DSP is currently the bus mas- 
ter. If the DSP is not the bus master, BS is cleared. In the slave mode, the BS bit is set 
when the BG output pin is high and cleared when BG is low. In the master mode, BS is 
cleared when the BG input pin is high and set when both pins (BG and BB) are low. This 
bit is set by hardware reset. 

1 28 locations of the external data space (X:$FF00-FF7F) are reserved for off-chip periph- 
eral accesses. The external bus access time on this external peripheral space is con- 
trolled by 5 bits of BCR2 located at X:$FFDA. Between and 31 software programmable 
wait states can be generated. A special pin, PEREN, is asserted low during accesses to 
the memory mapped external peripheral registers. Wait state fields are set to $1 F during 
hardware reset. 

4.2.1.2 Port B and Port C Registers 

Port B consists of three read/write registers — a 1 -bit Port B Control Register (PBC), a 1 5- 
bit Port B Data Direction Register (PBDDR), and a 15-bit Port B Data Register (PBD). 

Port C consists of three read/write registers — a 12-bit Port C Control Register (PCC), a 
12-bit Port C Data Direction Register (PCDDR), and a 12 bit Port C Data Register (PCD). 
Only ten bits in these three registers have pins and are available for GPIO. Bits 3 and 8 
are not connected to pins. These registers are shown in Figure 4-3. All registers are read/- 
write. Bit manipulation instructions can be used to access individual bits. 
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Figure 4-3 DSP56166 I/O Port B and C Programming Models 
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5.1. INTRODUCTION 

The Host Interface (HI) is a byte-wide parallel slave port which may be connected directly 
to the data bus of a host processor. The host processor may be any of a number of pop- 
ular microcomputers or microprocessors, another DSP, or DMA hardware. The 
DSP56166 has an 8-bit bidirectional data bus H0-H7 (PB0-PB7) and 7 control lines 
HR/W, HEN, HREQ, HA0-HA2, and HACK (PB8-PB14) to control data transfers. The HI 
pin functions are described in Section 2. The HI appears as a memory mapped peripheral, 
occupying 8 bytes in the host processor's address space and three words in the DSP pro- 
cessor's address space. Figure 5-1 shows the HI block diagram. Separate transmit and 
receive data registers are double-buffered to allow the DSP56166 and host processor to 
efficiently transfer data at high speed. Host processor communication with the HI registers 
is accomplished using standard host processor instructions and addressing modes. Host 
processors may use byte move instructions to communicate with the HI registers. The 
host registers are addressed so that 8-bit MC6801-type host processors can use 16-bit 
load (LDD) and store (STD) instructions for data transfers. The 16-bit MC68000/10 host 
processor can address the HI using the special MOVEP instruction for word (16-bit) or 
long word (32-bit) transfers. The 32-bit MC68020 host processor can use its dynamic bus 
sizing feature to address the HI using standard MOVE word (16-bit) or long word (32-bit) 
instructions. 

Handshake flags are provided for polled or interrupt-driven data transfers. The DSP561 66 
interrupt response is sufficiently fast that most host microprocessors can load or store 
data at their maximum programmed I/O (non-DMA) instruction rate without testing the 
handshake flags for each transfer. If the full handshake is not needed, the host processor 
can treat the DSP561 66 as fast memory and data can be transferred between the host 
and DSP56166 at the fastest host processor rate. DMA hardware may be used with the 
external Host Request and Host Acknowledge pins to transfer data at the maximum 
DSP56166 interrupt rate. 

The host processor can also issue vectored exception requests to the DSP561 66 with the 
host command feature. The host may select any of the 64 DSP exception routines to be 
executed by writing a vector address register. This flexibility allows the host programmer 
to execute a wide variety of preprogrammed functions inside the DSP561 66. Host excep- 
tions can allow the host processor to read or write DSP56166 registers, data memory, or 
program memory locations and perform control and debugging operations if exception 
routines are implemented in the DSP to do these tasks. 

The DSP5616 core views the HI as a memory mapped peripheral occupying three 16-bit 
words in data memory space. The DSP56166 may access the HI as a normal memory- 
mapped peripheral using standard polled or interrupt programming techniques. 
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Figure 5-1 Host Interface Block Diagram 
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5.2. HOST INTERFACE PROGRAMMING MODEL 

The HI has two programming models — one for the DSP56166 programmer and one for 
the host processor programmer. In most cases, the notation used in this manual reflects 
the DSP56166 perspective. The Host Interface — DSP56166 Programming Model is 
shown in Figure 5-2. The programming model register names on the DSP CPU side of the 
HI begin with the letter "H". The Host Interface — Host Processor Programming Model is 
shown in Figure 5-3. The HI Interrupt Structure is shown in Table 5-2. 

5.3. HOST TRANSMIT DATA REGISTER (HTX) 

The Host Transmit Register (HTX) is used for DSP to host processor data transfers. The 
HTX register is viewed as a 1 6-bit write-only register by the DSP. Writing the HTX register 
clears HTDE. The DSP may program the HTIE bit to cause a Host Transmit Data interrupt 
when HTDE is set. The HTX register is transferred as 1 6-bit data to the receive byte reg- 
isters RXH:RXL if both the HTDE bit and the Receive Data Full, RXDF, status bit are 
cleared. This transfer operation sets RXDF and HTDE. 

5.4. RECEIVE BYTE REGISTERS (RXH, RXL) 

The receive byte registers are viewed as two 8-bit read-only registers by the host proces- 
sor called Receive High (RXH) and Receive Low (RXL). These two registers receive data 
from the high byte and low byte respectively of the Host Transmit Data register HTX and 
are selected by three external Host Address inputs HA2, HA1 , and HAO during a host pro- 
cessor read operation or by an on-chip address counter in DMA operations. The receive 
byte registers (at least RXL) contain valid data when the Receive Data Register Full RXDF 
bit is set. The host processor may program the RREQ bit to assert the external Host Re- 
quest HREQ pin when RXDF is set. This informs the host processor or DMA controller 
that the receive byte registers are full. These registers may be read in any order to transfer 
8- or 16-bit data. However, reading RXL clears the Receive Data Full RXDF bit. Because 
reading RXL clears the RXDF status bit. RXL is normally the last register read during a 
1 6-bit data transfer. 

5.5. TRANSMIT BYTE REGISTERS (TXH, TXL) 

The transmit byte registers are viewed by the host processor as two 8-bit write-only reg- 
isters called Transmit High (TXH) and Transmit Low (TXL). These two registers send data 
to the high byte and low byte respectively of the Host Receive Data register (HRX) and 
are selected by three external Host Address inputs HA2, HA1 , and HAO during a host pro- 
cessor write operation. Data may be written into the transmit byte registers when the 
Transmit Data Register Empty TXDE bit is set. The host processor may program the 
TREQ bit to assert the external Host Request HREQ pin when TXDE is set. This informs 
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the host processor or DMA controller that the transmit byte registers are empty. These 
registers may be written in any order to transfer 8- or 16-bit data. However, writing the 
Transmit Low register TXL clears the TXDE bit. Because writing the TXL register clears 
the TXDE status bit, TXL is normally the last register written during a 16-bit data transfer. 
The transmit byte registers TXH:TXL are transferred as 16-bit data to the Host Receive 
Data Register HRX when both TXDE bit and the Host Receive Data Full, HRDF, bit are 
cleared. This transfer operation sets TXDE and HRDF 
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Figure 5-2 Host Interface — DSP Programming Model 

5.6. HOST RECEIVE DATA REGISTER (HRX) 

The Host Receive Data register (HRX) is used for host processor to DSP data transfers. 
The HRX register is viewed as a 16-bit read-only register by the DSP. The HRX register 
is loaded with 16-bit data from the Transmit Data Registers TXH: TXL when both the 
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Transmit Data Register Empty, TXDE, and Host Receive Data Full, HRDF, bits are 
cleared. This transfer operation sets TXDE and HRDF. The HRX register contains valid 
data when the HRDF bit is set. Reading HRX clears HRDF. The DSP may program the 
HRIE bit to cause a Host Receive Data interrupt when HRDF is set. 

5.7. COMMAND VECTOR REGISTER (CVR) 

The CVR is used by the host to request vectored exception service from the DSP of any 
exception routine in the DSP. The Host Command feature is independent of any of the 
data transfer mechanisms in the HI but can be used to initialize the DSP for data transfer 
by triggering the appropriate preprogrammed software routine. 
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5.7.1 CVR Host Vector (HV) Bits through 4 

The 5-bit Host Vector (HV) selects the host command exception address to access the 
host command exception routine. When the Host Command Exception is recognized by 
the DSP interrupt control logic, the starting address of the exception taken is 2*HV. This 
allows the host processor to provide the exception starting address for the Host Com- 
mand Exception. The host processor can select any of the 64 possible exception routine 
starting addresses in the DSP by writing the exception routine starting address (divided 
by 2) into HV. This means that the host processor can force any of the existing exception 
handlers (SSI, TIMER, IRQA, IRQB, etc.) and can use any of the reserved or otherwise 
unused starting addresses provided they are pre-programmed in the DSP. HV is set to 
$1 6 (vector location $002C) by DSP reset. 

CAUTION: 
The HV should not be used with a value of zero because the 
reset location is normally programmed with a JMP instruction. 
This will cause an improper fast exception. 

5.7.2 CVR Reserved Bits - Bits 5 and 6 

Reserved bits are unused and are read by the host as zeros. Reserved bits should be writ- 
ten as zero for future compatibility. 
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Figure 5-3 Host Interface — Host Processor ProgrammSng Model 
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Table 5-1 Host Interface Interrupt Structure 

5.7.3 CVR Host Command Bit (HC) Bit 7 

The Host Command bit (HC) is used by the host to handshake the execution of host com- 
mand exceptions. Normally the host processor sets HC=1 to request the host command 
exception from the DSP. When the host command exception is taken by the DSP, the HC 
bit is cleared by the HI hardware. The host processor can read the state of HC to deter- 
mine when execution of the host command has started. The host processor may elect to 
clear the HC bit, cancelling the Host Command Exception request at any time before it is 
recognized by the DSP. 

CAUTION: 

The command exception might be recognized by the DSP and 
executed before it can be canceied by the host, even if the 
host clears the HC bit 

Setting HC causes HCP (Host Command Pending) to be set in the HSR register. The host 
can write HC and HV in the same write cycle if desired. HC is cleared by DSP reset. 

5.8. HOST CONTROL REGISTER (HCR) 

The Host Control Register (HCR) is an 8-bit read/write control register used by the DSP 
to control the HI interrupts and flags. HCR cannot be accessed by the host processor. The 
HCR register occupies the low order byte of the internal data bus — the high order portion 
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is zero filled. HCR is a read/write register which can be accessed using bit manipulation 
instructions on control register bits. Any reserved bits are read as zeros and should be 
programmed as zeros for future compatibility. The contents of HCR are cleared on DSP 
reset. The control bits are described in the following paragraphs. 
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5.8.1 HCR Host Receive Interrupt Enable (HRIE) Bit 

The Host Receive Interrupt Enable (HRIE) bit is used to enable a DSP interrupt when the 
Host Receive Data Full (HRDF) status bit in the Host Status register (HSR) is set. When 
HRIE is cleared, HRDF interrupts are disabled. When HRIE is set, a Host Receive Data 
interrupt request will occur if HRDF is set. 

5.8.2 HCR Host Transmit Interrupt Enable (HTIE) Bit 1 

The Host Transmit Interrupt Enable (HTIE) bit is used to enable a DSP interrupt when the 
Host Transmit Data Empty (HTDE) status bit in the Host Status Register (HSR) is set. 
When HTIE is cleared, HTDE interrupts are disabled. When HTIE is set, a Host Transmit 
Data interrupt request will occur if HTDE is set. 

5.8.3 HCR Host Command Interrupt Enable (HCIE) Bit 2 

The Host Command Interrupt Enable (HCIE) bit is used to enable a vectored DSP inter- 
rupt when the Host Command Pending (HCP) status bit in the Host Status Register (HSR) 
is set. When HCIE is cleared, HCP interrupts are disabled. When HCIE is set, a Host 
Command interrupt request will occur if HCP is set. The starting address of this interrupt 
is determined by the Host Vector (HV). 

5.8.4 HCR Host Flag 2 (HF2) Bit 3 

The Host Flag 2 (HF2) bit is used as a general purpose flag for DSP to host processor 
communication. Changing HF2 will change the Host Flag 2 (HF2) bit of the Interrupt Sta- 
tus Register ISR on the host processor side of the host interface. HF2 may be set or 
cleared by the DSP. 

5.8.5 HCR Host Flag 3 (HF3) Bit 4 

The Host Flag 3 (HF3) bit is used as a general purpose flag for DSP to host processor 
communication. Changing HF3 will change the Host Flag 3 (HF3) bit of the Interrupt Sta- 
tus Register ISR on the host processor side of the host interface. HF3 may be set or 
cleared by the DSP. 
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5.8.6 HCR Reserved Control - Bits 5, 6, and 7 

These unused bits are reserved for future expansion and should be written with zeros for 
future compatibility. 

5.9. HOST STATUS REGISTER (HSR) 

The Host Status register (HSR) is an 8-bit read-only status register used by the DSP to 
interrogate HI status and flags. It cannot be directly accessed by the host processor, 
When the HSR register is read to the internal data bus, the register contents occupy the 
low order byte of the data bus — the high order portion is zero filled. The status bits are 
described in the following paragraphs. 
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5.9.1 HSR Host Receive Data Full (HRDF) Bit 

The Host Receive Data Full (HRDF) bit indicates that the Host Receive Data register 
(HRX) contains data from the host processor. HRDF is set when data is transferred from 
the TXH:TXL registers to the HRX register. HRDF is cleared when the Receive Data reg- 
ister HRX is read by the DSP. HRDF can also be cleared by the host processor using the 
Initialize function. HRDF is also cleared by a DSP reset. This bit is typically used for polling 
operations. 

5.9.2 HSR Host Transmit Data Empty (HTDE) Bit 1 

The Host Transmit Data Empty (HTDE) bit indicates that the Host Transmit Data register 
(HTX) is empty jand can be written by the DSP. HTDE is set when the HTX register is 
transferred to the RXH:RXL registers. HTDE is cleared when the Transmit Data register 
HTX is written by the DSP. HTDE can also be set by the host processor using the Initialize 
function. HTDE is also set by a DSP reset. This bit is typically used for polling operations. 

5.9.3 HSR Host Command Pending (HCP) Bit 2 

The Host Command Pending (HCP) bit indicates that the host processor has set the HC 
bit and that a Host Command Interrupt is pending. The HCP bit reflects the status of the 
HC bit in the Command Vector Register (CVR) on the host processor side of the host in- 
terface. HC and HCP are cleared by the DSP exception hardware when the exception is 
taken. The host processor can clear HC which also clears HCP. The HCP is cleared by 
DSP reset. This bit is typically used for polling operations. 
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5.9.4 HSR Host Rag (HFO) Bit 3 

The Host Flag (HFO) bit indicates the state of Host Flag (HFO) in the Interrupt Control 
Register ICR on the host processor side of the host interface. HFO can only be changed 
by the host processor. HFO is cleared by a DSP reset. 

5.9.5 HSR Host Rag 1 (HF1) Bit 4 

The Host Flag 1 (HF1) bit indicates the state of Host Flag 1 (HF1) in the Interrupt Control 
Register ICR on the host processor side of the host interface. HF1 can only be changed 
by the host processor. HF1 is cleared by a DSP reset. 

5.9.6 HSR Reserved Status - Bits 5 and 6 

These status bits are reserved for future expansion and read as zero during DSP read op- 
erations. Reserved bits should be written as zero for future compatibility. 

5.9.7 HSR DMA Status (DMA) Bit 7 

The DMA status bit (DMA) indicates that the host processor has enabled the DMA mode 
of the HI by setting HM1 or HMO to a one. When the DMA status bit is a zero, it indicates 
that the DMA mode is disabled by the Host Mode bits HMO and HM1 (both are cleared) in 
the Interrupt Control Register ICR and no DMA operations are pending. When the DMA 
status bit is set, the DMA mode is enabled by the Host Mode bits HMO and HM1 . The 
channel not in use (i.e., the transmit channel or receive channel) can be used for polled 
or interrupt operation by the DSP. DMA is cleared by a DSP reset. 

5.10. INTERRUPT CONTROL REGISTER (ICR) 

The Interrupt Control Register (ICR) is an 8-bit read/write control register used by the host 
processor to control the HI interrupts and flags. ICR cannot be accessed by the DSP. ICR 
is a read/write register which can be accessed using bit manipulation instructions on con- 
trol register bits. The control bits are described in the following paragraphs. 
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5.10.1 ICR Receive Request Enable (RREQ) Bit 

The Receive Request enable (RREQ) bit is used to control the HREQ pin for host receive 
data transfers. In the Interrupt Mode (DMA off), RREQ is used to enable interrupt requests 
via the external Host Request HREQ pin when the Receive Data Register Full (RXDF) 
status bit in the Interrupt Status register (ISR) is set. When RREQ is cleared, RXDF inter- 
rupts are disabled. When RREQ is set, the external Host Request HREQ pin will be as- 
serted if RXDF is set. 
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In DMA modes, RREQ must be set or cleared by software to select the direction of DMA 
transfers. Setting RREQ sets the direction of the DMA transfer to be from DSP to host, 
and enables the HREQ pin to request these data transfers. RREQ is cleared by DSP re- 
set. 

5.10.2 ICR Transmit Request Enable (TREQ) Bit 1 

The Transmit Request enable (TREQ) bit is used to control the HREQ pin for host transmit 
data transfers. In the Interrupt Mode (DMA off), TREQ is used to enable interrupt requests 
via the external Host Request HREQ pin when the Transmit Data Register Empty (TXDE) 
status bit in the Interrupt Status register (ISR) is set. When TREQ is cleared, TXDE inter- 
rupts are disabled. When TREQ is set, the external Host Request HREQ pin will be as- 
serted if TXDE is set. 

In DMA modes, TREQ must be set or cleared by software to select the direction of DMA 
transfers. Setting TREQ sets the direction of the DMA transfer to be from host to DSP and 
enables the HREQ pin to request these data transfers. 



Table 5-2 and Table 5-3 summarize the effect of RREQ and TREQ on the HREQ pin. 
TREQ is cleared by DSP reset. 

5.10.3 ICR Reserved bit - Bit 2 

This bit is reserved and unused. It reads as a logic zero. Reserved bits should be written 
as zero for future compatibility. 

Table 5-2 HREQ Pin Definition - Interrupt Mode 



TREQ 


RREQ 


HREQ Pin 




1 
1 



1 


1 


No Interrupts (Polling) 

RXDF Request (Interrupt) 

TXDE Request (Interrupt) 

RXDF and TXDE Request (Interrupt) 



Table 5-3 HREQ Pin Definition - DMA Mode 



TREQ 


RREQ 


HREQ Pin 




1 
1 



1 


1 


DMA Transfers Disabled 
DSP-* HOST Request (RX) 
HOST-> DSP Request (TX) 
Undefined (Illegal) 



5.10.4 ICR Host Flag (HFO) Bit 3 

The Host Flag (HFO) bit is used as a general purpose flag for host processor to DSP 
communication. HFO may be set or cleared by the host processor and cannot be changed 
by the DSP. Changing HFO also changes the Host Flag bit (HFO) of the Host Status reg- 
ister HSR on the DSP side of the HI. HFO is cleared by DSP reset. 
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5.10.5 ICR Host Flag 1 (HF1) Bit 4 

The Host Flag 1 (HF1) bit is used as a general purpose flag for host processor to DSP 
communication. HF1 may be set or cleared by the host processor and cannot be changed 
by the DSP. Changing HF1 also changes the Host Flag bit 1 (HF1) of the Host Status reg- 
ister HSR on the DSP side of the HI. HF1 is cleared by a DSP reset. 

5.10.6 ICR Host Mode Control (HM1 , HMO) Bits 5 and 6 

The Host Mode control bits HMO and HM1 select the transfer mode of the HI. HM1 and 
HMO enable the DMA mode of operation or interrupt (non-DMA) mode of operation. 

When the DMA mode is en abled, t he HREQ pin is used as a DMA transfer request output 
to a DMA controller and the HACK pin is used as a DMA Transfer Acknowledge input from 
a DMA controller. The DMA Control bits HMO and HM1 select the size of the DMA word 
to be transferred as shown in Table 5-4. The direction of the DMA transfer is selected by 
the TREQ and RREQ bits. 

Table 5-4 Host Mode (HM1, HMO) Bit Definition 



HM1 


HMO 


Mode 





1 
1 



1 


1 


Interrupt Mode (DMA off) 

Illegal 

DMA mode; 16-bit 

DMA mode; 8-bit 



When both HM1 and HMO are cleared, the DMA mode is disabled and the TREQ and 
RREQ control bits are used for host processor interrupting via the external Host Request 
HREQ output pin. In the interrupt mode, the Host Acknowledge HACK input pin is used 
for the MC68000 family vectored Interrupt Acknowledge input. 



When HM1 or HMO are set, the DMA mode is enabled and the HREQ pin is not available 
for host processor interrupts. When the DMA mode is enabled, the TREQ and RREQ bits 
select the direction of DMA transfers; the Host Acknowledge HACK input pin is used as a 
DMA Transfer Acknowledge input. If the DMA direction is from DSP to Host, the contents 
of the selected register are enabled onto the host data bus when HACK is asserted. If the 
DMA direction is from Host to DSP, the selected register is written to TXH or TXL from the 
host data bus when HACK is asserted. The size of the DMA word to be transferred is de- 
termined by the DMA control bits HMO and HM1 . The HI register selected during a DMA 
transfer is determined by a 2-bit address counter which is preloaded with the value in HM1 
and HMO. The address counter substitutes for the Host Address bits HA1 and HAO of the 
HI during a DMA transfer. The Host Address bit HA2 is forced to one during each DMA 
transfer. The address counter can be initialized with the INIT bit feature. After each DMA 
transfer on the host data bus, the address counter is incremented to the next register. 
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When the address counter reaches the highest register (RXL or TXL), the address 
counter is not incremented but is loaded with the value in HM1 and HMO. This allows 8- 
or 16-bit data to be transferred in a circular fashion and eliminates the need for the DMA 
controller to supply the Host Address HA2, HA1 , and HAO pins. For 16-bit data transfers, 
the DSP interrupt rate is reduced by a factor of two from the Host Request rate. 

HM1 and HMO are cleared by DSP reset. 

5.10.7 ICR Initialize Bit (INIT) Bit 7 

The INIT bit is used by the host to force initialization of the HI hardware. This may or may 
not be necessary, depending on the software design of the interface. The type of initial- 
ization done depends on the state of TREQ and RREQ. The INIT command is designed 
to conveniently convert into the desired data transfer mode after the INIT is completed. 
The commands are described below and in Table 5-5. The host sets INIT which causes 
the HI hardware to execute the command. The interface hardware clears INIT when the 
command is complete. INIT is cleared by DSP reset. 

Note that INIT execution always loads the DMA address counter and clears the channel 
according to TREQ and RREQ. INIT execution is not affected by HM1 and HMO. 

Table 5-5 INIT Execution Definition 



n 



TREQ 


RREQ 


After INIT Execution — Interrupt Mode (HM1=0, HM0=0) 




1 
1 



1 

1 


INIT=0; "address counter = 00" 
INIT=0; RXDF=0; HTDE=1 ; "address counter = 00" 
INIT=0; TXDE=1 ; HRDF=0; "address counter = 00" 
INIT=0; RXDF=0; HTDE=1 ; TXDE=1 ; HRDF=0; 

"address counter = 00" 





Table 5-5 INIT Execution Definition (Continued) 


TREQ 


RREQ 


After INIT Execution — DMA Mode (HM1 or HMO = 1) 




1 
1 



1 

1 


INIT=0; address counter = HM1 ,HM0 
INIT=0; RXDF=0; HTDE=1; address counter = HM1.HM0 
INIT=0; TXDE=1 ; HRDF=0; address counter = HM1 5 HM0 
Undefined (illegal) 



5.1 1 . INTERRUPT STATUS REGISTER (ISR) 

The Interrupt Status register (ISR) is an 8-bit read-only status register used by the host 
processor to interrogate the status and flags of the HI. The ISR can not be accessed by 
the DSP. The status bits are described in the following paragraphs. 
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5.1 1 .1 ISR Receive Data Register Full (RXDF) Bit 

The Receive Data Register Full (RXDF) bit indicates that both the receive byte registers, 
RXH and RXL, contain data from the DSP and may be read by the host processor. RXDF 
is set when the contents of the Host Transmit Data Register HTX is transferred to the re- 
ceive byte registers RXH:RXL RXDF is cleared when the Receive Data Low (RXL) reg- 
ister is read by the host processor. RXL is normally the last byte of the receive byte reg- 
isters to be read by the host processor. RXDF can be cleared by the host processor using 
the Initialize function. RXDF is cleared by a DSP reset. RXDF may be used to assert the 
external Host Request HREQ pin if the Receive Request enable RREQ bit is set. RXDF 
provides valid status regardless of whether the RXDF interrupt is enabled or not so that 
polling techniques may be used by the host processor. 

5.1 1 .2 ISR Transmit Data Register Empty (TXDE) Bit 1 

The Transmit Data Register Empty (TXDE) bit indicates that the transmit byte registers 
TXH and TXL are both empty and can be written by the host processor. TXDE is set when 
the content of the transmit byte registers TXH:TXL are transferred to the Host Receive 
Data Register (HRX). TXDE is cleared when the Transmit Byte Low (TXL) register is writ- 
ten by the host processor. TXL is normally the last byte of the transmit byte registers to 
be written by the host processor. TXDE can be set by the host processor using the Initial- 
ize featu re. TXD E is set by a DSP reset. TXDE may be used to assert the external Host 
Request HREQ pin if the Transmit Request Enable TREQ bit is set. TXDE provides valid 
status regardless of whether the TXDE interrupt is enabled or not so that polling tech- 
niques may be used by the host. 

5.1 1 .3 ISR Transmitter Ready (TRDY) Bit 2 

The Transmitter Ready (TRDY) status bit indicates that both the transmit byte registers 
and Host Receive Data register are empty, i.e., the channel from the host processor 
through the HI to the DSP CPU is clear. By testing TRDY, the host processor programmer 
can be assured that the first word received by the DSP will be the first word the host pro- 
cessor transmits. 

TRDY = TXDE A HRDF 
The DSP reset will set TRDY. 
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5.1 1 .4 ISR Host Flag 2 (HF2) Bit 3 

The Host Flag 2 (HF2) bit indicates the state of Host Flag 2 (HF2) in the Host Control Reg- 
ister (HCR). HF2 can only be changed by the DSP. HF2 is cleared by a DSP reset. 

5.1 1 .5 ISR Host Flag 3 (HF3) Bit 4 

The Host Flag 3 (HF3) bit indicates the state of Host Flag 3 (HF3) in the Host Control Reg- 
ister HCR. HF3 can only be changed by the DSP. HF3 is cleared by a DSP reset. 

5.1 1 .6 ISR (Reserved Status) Bit 5 

This status bit is reserved for future expansion and will read as zero during host processor 
read operations. Reserved bits should be written as zero for future compatibility. 

5.11.7 ISR DMA Status (DMA) Bit 6 

The DMA status bit (DMA) indicates that the host processor has enabled the DMA mode 
of the HI (HM1 or HMO =1). When the DMA status bit is clear, it indicates that the DMA 
mode is disabled by the Host Mode bits (HMO and HM1) in the Interrupt Control Register 
ICR and no DMA operations are pending. When DMA is set, it indicates that the DMA 
mode is enabled and the host processor should not use the active DMA channel (RX- 
H:RXL or TXHTXL depending on DMA direction) to avoid conflicts with the DMA data 
transfers. 

5.1 1 .8 ISR Host Request (HREQ) Bit 7 



ra 



The Host Request (HREQ) bit indicates the status of the external Host Requ est HR EQ 
output pin. When the HREQ status bit is cleared, it indicates that the external HREQ pin 
is deasserted and no host interrupts or DMA transf ers ar e being requested. When the 
HREQ status bit is set, it indicates that the external HREQ pin is asserted indicating that 
the DSP is interrupting the host processor or that a DMA transfer request is being made. 
The HREQ interrupt request may originate from one or more of two sources — the receive 
byte registers are full or the transmit byte registers are empty. These conditions are indi- 
cated by the Interrupt Status register (ISR) RXDF and TXDE status bits, respectively. If 
the interrupt source has been enabled by the associated request enable bit in the Interrupt 
Control Register ICR, HREQ will be set if one or more of the two enabled interrupt sources 
is set. DSP reset will clear HREQ. 

5.12. INTERRUPT VECTOR REGISTER (IVR) 

The Interrupt Vector Register (IVR) is an 8-bit read/write register which contains the ex- 
ception vector number for use with MC68000 processor family vectored interrupts. This 
register is accessible only to the host pro cessor . Th e conte nts of the IVR register are 
placed on the host data bus, H0-H7, when HREQ and HACK pins both are asserted and 
the DMA mode is disabled. The content of this register is initialized to $0F by a DSP reset. 
This corresponds to the un-initialized exception vector in the MC68000 family. 
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5.13. IVR HOST INTERFACE INTERRUPTS 

The HI may request interrupt service from either the DSP or host processor. The DSP in- 
terrupts are internal and do not require the use of an external interrupt pin. The DSP ac- 
knowledges host interrupts by jumping to the appropriate interrupt service routine. The 
DSP interrupt service routine must read or write the appropriate HI register (e.g. clearing 
HRDF or HTDE) to clear the interrupt. In the case of Host Command interrupts, the inter- 
rupt acknowledge from the program controller will clear the pending interrupt condition. 



The host processor interrupts are external and use the Host Request HREQ pin. HREQ 
is normally connected to the host processor maskable interrupt (IRQ) input. The host pro- 
cessor acknowledges host interrupts by executing an interrupt service routine. The 
MC68000 processor family will assert the HACK pin to read the exception vector number 
from the Interrupt Vector Register (IVR) of the HI. The most significant bit (HREQ) of the 
Interrupt Status Register (ISR) may be tested to determine if the DSP is the interrupting 
device and the two least significant bits (RXDF and TXDE) may be tested to determine 
the interrupt source. The host processor interrupt service routine must read or write the 
appropriate HI register to clear the interrupt. 

5.14. DMA MODE OPERATION 

The DMA mode allows the transfer of 8-bit or 1 6-bit data between the DSP HI and an ex- 
ternal DMA controller. The HI provides the pipeline data registers and the synchronization 
logic between the two asynchronous processor systems. The DSP host exceptions pro- 
vide cycle-stealing data transfers with the DSP internal or external memory. This allows 
the DSP memory address to be generated using any of the DSP addressing modes and 
modifiers. Queues and circular sample buffers are easily created for DMA transfer re- 
gions. The DSP host exceptions appear as high priority fast or long exception service rou- 
tines. The external DMA controller provides the transfers between the DSP HI registers 
and the externa! DMA memory. The external DMA controller must provide the address to 
the externa! DMA memory. The address of the selected HI register is provided by a DMA 
address counter in the DSP HI. 

5.1 4.1 Host to DSP - Host Interface Action 

The following procedure outlines the steps that the HI hardware takes to transfer DMA 
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data from the host data bus to DSP memory. 



1 . Assert the Host Request HREQ output pin when the transmit byte registers TXH:TXL 
are empty (this always occurs in host to DSP DMA mode when TXDE=1). 



2. Write the selected transmit byte register from the host data bus when the HACK input 
pin is asserted by the DMA controller. Deassert the HREQ pin. 

3. If the highest register address has not been reached (i.e., TXDE=1), postincrement the 
DMA address counter to select the next register. Wait until HACK is deasserted then 
go to step 1 . 

4. If the highest register address has been reached (i.e., TXDE=0), load the DMA ad- 
dress counter with the value in HM1 and HMO and transfer the transmit byte registers 
TXH:TXL to the H ost Re ceive Data Register HRX when HRDF=0. This will set 
HRDF=1 . Wait until HACK is deasserted then go to step 1 . 

Notes: 

1 . The DSP to host data transfers can occur normally in the channel not used for DMA 
except that the host must use polling and not interrupts. 

2. The transfer of data from the TXH :TXL register to the HRX register automatically loads 
the DMA address counter from the HM1 and HMO bits in the DMA host to DSP mode. 

The host exception is triggered when HRDF=1 . The host exception routine must read the 
Host Receive Data Register HRX to clear HRDF. The transfer from step 4 to step 1 will 
automatically occur if TXDE=1 . Note that the execution of the host exception on HRDF=1 
condition will occur after the transfer to step 1 and is independent of the handshake since 
it is only dependent on HRDF=1 . 

5.14.2 Host to DSP - Host Processor Procedure 

The following procedure outlines the typical steps that the host processor must take to set- 
up and terminate a host to DSP DMA transfer. 

1. Setup the external DMA controller source address, direction, byte count, and other 
control registers. Enable the DMA controller channel. 

2. Set TXDE and clear HRDF. This can be done with the appropriate Initialize function. 
The host must also initialize the DMA counter in the HI using the initialize feature. 

3. The DSP's destination pointer used in the DMA exception handler (an address register 
for example) must be initialized and HRIE must be set to enable the HRDF interrupt. 
This co uld be done with a separate Host Command exception routine in the DSP. 
HREQ output pin will be asserted immediately by the DSP hardware which begins the 
DMA transfer. 
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4. Perform other tasks until interrupted by the DMA controller DMA complete interrupt. 
The DSP Interrupt Control Register (ICR), the Interrupt Status Register (ISR), and 
RXH:RXL may be accessed at any time by the host processor (using HA0-HA2, HRA/V, 
and HEN) but the transmit byte registers (TXH:TXL) may not be accessed until the 
DMA mode is disabled. 

5. Terminate the DMA controller channel to disable DMA transfers. 

6. Terminate the DSP HI DMA mode by clearing the HM1 and HMO bits and clearing 
TREQ in the Interrupt Control Register (ICR). 

5.14.3 DSP to Host Interface Action 

The following procedure outlines the steps that the HI hardware takes to transfer DMA 
data from DSP memory to the host data bus. 

1. The transmit exception will be triggered when HTIE=1 and HTDE=1. The exception 
routine software will write the data word into HTX. 

2. Transfer the HTX register to the receive byte registers RXH:RXL when they are empty 
(RXDF=0). This will automatically occur. Load the DMA address counter from HM1 
and HMO. This action will set HTDE=1 and trigger another DSP transmit exception to 
write HTX (i.e., HTDE=0). 



3. Assert the Host Request HREQ pin when the receive byte registers are full. 



4. Enable the selected Receive Byte register on the host data bus when HACK is assert- 
ed. Deassertthe Host Request HREQ pin. 

5. If the highest register address has not been reached (i.e. , RXDF=1 ), postincrement the 
DMA address counter to select the next register. Wait until HACK is deasserted, then 
go to step 3. 

6. If the highest register address has been reached (i.e., RXDF=0), wait until HACK is 
deasserted then go to step 2. The DSP transmit exception must have written HTX (i.e., 
HTDE=0) before Step 2 will be executed. 

Notes: 

1 . The HOST™> DSP data transfers can occur normally in the channel not used for DMA 
except that the host must use polling and not interrupts. 

2. The transfer of data from the HTX register to the RXH:RXL registers automatically 
loads the DMA address counter from the HM1 and HMO bits when in DMA DSP to Host 
mode. 
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5.14.4 DSP to Host - Host Processor Procedure 

The following procedure outlines the typical steps that the host processor must take to set- 
up and terminate a DSP to host DMA transfer. 

1 . Setup the DMA controller destination address, direction, byte count, and other control 
registers. Enable the DMA controller channel. 

2. Set HTDE and clear RXDF. This can be done with the appropriate INIT function. 

3. The DSP's source pointer used in the DMA exception handler (an address register for 
example) must be initialized and HTIE must be set to enable the DSP host transmit 
interrupt. This could be done by the host with a Host Command exception routine. The 
DSP host transmit exception will be activated immediately by DSP hardware which be- 
gins the DMA transfer. 

4. Perform other tasks until interrupted by the DMA controller DMA complete interrupt. 
The DSP Interrupt Control Register (ICR), the Interrupt Status Register (ISR), and 
TXH:TXL may be accessed at any time by the host processor (using HA0-HA2, HR/W, 
and HEN) but the receive byte registers (RXH and RXL) may not be accessed until the 
DMA mode is disabled. 

5. Terminate the DMA controller channel to disable DMA transfers. 

6. Terminate the DSP HI DMA mode by clearing the HM1 and HMO bits and clearing 
RREQ in the Interrupt Control Register (ICR). 

5.15. HOST PORT USAGE - GENERAL CONSIDERATIONS 

Careful synchronization is required when reading multi-bit registers that are written by an- 
other asynchronous system. This is a common problem when two asynchronous systems 
are connected. The situation exists in the host port. However, if the port is used in the way 
it was designed, proper operation is guaranteed. The considerations for proper operation 
are discussed below. 

5.15.1 Host Programmer Considerations 

1 . Unsynchronized Reading of receive byte registers. 

When reading receive byte registers, RXH or RXL, the host programmer should use 
interrupts or poll the RXDF flag which indicates that data is available. This guarantees 
that the data in the receive byte registers will be stable. 

2. Overwriting transmit byte registers. 
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The host programmer should not write to the transmit byte registers, TXH or TXL, un- 
less the TXDE bit is set, indicating that the transmit byte registers are empty. This 
guarantees that the DSP will read stable data when it reads the HRX register. 

3. Synchronization of Status Bits from DSP to Host. 

HC, HREQ, DMA, HF3, HF2, TRDY, TXDE, and RXDF status bits are set or cleared 
from inside the DSP and read by the host processor. The host can read these status 
bits very quickly without regard to the clock rate used by the DSP but there is a chance 
that the state of the bit could be changing during the read operation. This is generally 
not a system problem since the bit will be read correctly in the next pass of any host 
polling routine. However, if the host holds the HEN input pin for the minimum assert 
time plus 1 .5 Ccyc, the status data is guaranteed to be stable. The 1 .5 Ccyc is first 
used to synchronize the HEN signal and then to block internal updates of the status 
bits. There is no other minimum HEN assert time relationship to the DSP clocks. There 
is a minimum HEN deassert time of 1 .5 Ccyc so that the blocking latch can be deas- 
serted to allow updates if the host is in a tight polling loop. This only applies to reading 
status bits. 

The only potential system problem with the uncertainty of reading any status bits by 
the host is HF3 and HF2 as an encoded pair. For example, if the DSP changes HF3 
and HF2 from "00" to "1 1 ", there is a very small probability that the host could read the 
bits during the transition and receive "01" or "10" instead of "11". If the combination of 
HF3 and HF2 has significance, the host would potentially read the wrong combination. 

Solutions: 

a. Read the bits twice and check for consensus. 



b. Assert HEN access for HEN + 1 .5 Ccyc so that status bit transitions are stabi- 
lized. 

4. Overwriting the Host Vector 

The host programmer should change the Host Vector register only when the Host 
Command bit (HC) is clear. This will guarantee that the DSP interrupt control logic will 
receive a stable vector. 

5. Cancelling a pending Host Command Exception 

The host processor may elect to clear the HC bit to cancel the Host Command Excep- 
tion request at any time before it is recognized by the DSP. The DSP may execute the 
host exception after the HC bit is cleared: (1 ) because the host does not know exactly 
when the exception will be recognized, (2) because of synchronization, and (3) be- 
cause of exception processing pipelining. As a result, the HV must not be changed at 
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the same time the HC bit is cleared. In this way, if the exception was taken, the vector 
will be known. 

5.15.2 DSP Programmer Considerations 

1 . Reading HF1 and HFO as an encoded pair. 

DMA, HF1 , HFO, HCP, HTDE, and HRDF status bits are set or cleared by the host pro- 
cessor side of the interface. These bits are individually synchronized to the DSP clock. 

The only system problem with reading status is HF1 and HFO if they are encoded as 
a pair, e.g. the four combinations 00, 01, 10, and 11 each have significance. This is 
because there is a very small probability that the DSP will read the status bits that were 
synchronized during transition. The solution to this potential problem is to read the bits 
twice for consensus. 
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6.1 INTRODUCTION 

This section describes the DSP56166 Sigma-Delta (LA) over sampled voice band codec 
block. It discusses the general block diagram of the A/D and D/A sections, the handshake 
between the DSP561 6 core and the codec, as well as the last decimation antialiasing filter 
and first interpolation reconstruction filter performed in software by the DSP5616 core. 

6.2 GENERAL DESCRIPTION 

The oversampied voice band codec block is built using HCMOS technology and utilizes 
switched capacitor technology in some circuits. The codec contains one A/D converter 
and one D/A converter. It also contains two reference voltage generators, a current bias 
generator, and a master clock circuit (see Figure 6-1). 



On-chip EA Codec Block 




DSP5616Core 

Decimation, 
Antialiasing 

and 
Compensation 

Interpolation, 
Reconstruction 

and 
Compensation 




Figure 6-1 DSP561 66 On-chip Functional Diagram 

The A/D converter consists of an analog modulator with selectable input gain, a digital 
low-pass comb filter, and a parallel bus interface. The analog modulator is a second-order 
loop implemented using fully differential CMOS switched capacitor circuitry. The analog 
modulator input is selectable from one of two pins. The analog modulator output is the in- 
put to a third-order digital comb filter which provides low-pass filtering and decimation. 
The final 16-bit result is output through a parallel interface to the global data bus of the 
DSP5616core. 

The D/A converter consists of a second-order comb interpolating filter, a digital modula- 
tor, a 1-bit DAC, a two-pole Butterworth low pass filter, a selectable attenuator, and an 
active RC low pass output stage. The interpolator takes in 1 6-bit two's complement num- 
bers from the DSP5616 core and upsamples them to a high frequency. The modulator 
changes these 16-bit words into a 1-bit stream. The 1-bit DAC converts this 1-bit stream 
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into 2 volt differential analog levels. The output of the DAC is filtered by the switched ca- 
pacitor Butterworth filter which attenuates the out-of-band shaped modulator noise. The 
selectable attenuator provides volume control in increments of 5 dB per step. The active 
RC low pass filter provides reconstruction filtering and driver capabilities. 

This codec block has been designed for maximum flexibility. The user can select any val- 
ue between 65 and 128 as the decimation (interpolation) ratio for the A/D (D/A) convert- 
ers. Operating at its nominal sampling rate of 2 MHz, the A/D converter provides a 16-bit 
digital output with more than 60 dB S/(N+D) for input signals. The D/A converter nominally 
takes in a 16-bit word at a 16 KHz rate, and has a fully differential analog output which 
provides more than of 60 dB S/(N+D).Table 6-1 summarizes the main features of the co- 
dec block. 

Table 6-1 On-chip Codec Main Features 



16-bit resolution 

Dynamic Range of 80 dB 

More than 60 dB S/(N+D) 

Operates at clock rates between 100 KHz and 3 MHz 

No off-chip component required 

Internal voltage reference (2/5 of positive power supply) 

Low power HCMOS 



The last decimation filtering stage of the A/D section as well as the first interpolation filter- 
ing stage of the D/A section is implemented by software in the 16-bit DSP core in order to 
reduce the codec cell die area. 

6.3 CODEC BLOCK DIAGRAM 

A general block diagram of the DSP561 66 codec and its programming model can be seen 
in Figure 6-2. 
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Figure 6-2 DSP56166 Codec General Block Diagram 

6.4 ANALOG I/O DEFINITION 

This section describes the Motorola DSP561 66 Codec analog input and output character- 
istics (see Figure 6-3). 

There are two analog inputs, MIC and AUX. Selection between MIC or AUX is made via 
one control bit (INS bit) and can be changed any time desired. The electrical specifications 
of the two pins are identical. 
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The analog output consists of a fully differential driver stage, with each output having an 
operating range of Vrda = 1 .0 Vp. The output op-amp is capable of driving a load of 1 k in 
series with 50 nF between the differential outputs. 
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Figure 6-3 DSP561 66 Codec Analog Input and Output Diagram 

The reference voltages for the A/D and D/A converters are generated by two on-chip volt- 
age references. Current bias for the opamps in the analog blocks are set by the on-chip 
current bias generator. 

6.5 INTERFACE WITH THE DSP561 6 CORE 

This section discusses the use of each bit in the codec control registers. 

6.5.1 Interface Definition 

The Codec is seen from the core as a memory mapped on-chip peripheral. Data memory 
locations are dedicated for the receive data register, transmit data register, status register, 
and control registers. One interrupt vector is assigned to the Codec. 
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The A/D section (receive) and the D/A section (transmit) are synchronous; that is, a com- 
mon interrupt vector is used by the two sections to notify the DSP core that an input sam- 
ple is to be read and/or that an output sample is to be written. 

6.5.2 On-chip Codec Programming Model 

Figure 6-4 shows the memory mapped registers used with the on-chip codec.There are 



five registers mapped into four memory locations. 



15 



On-chip Codec DATA REGISTERS 
8 7 



CRX REGISTER 



15 



CTX REGISTER 



On-chip Codec CONTROL and STATUS REGISTERS 
15 14 13 12 11 10 9 8 



COIE 


COE 


INS 


MGS1 


MGSO 


MUT 


* 


CLS 


7 


6 


5 


4 3 


2 


1 





CLB 


* 


* 


* 


VC3 


VC2 


VC1 


vco 



15 


14 


13 


12 


11 


10 


9 


8 


* 


* 


CRS5 


CRS4 


CRS3 


CRS2 


CRS1 


CRSO 


7 


6 


5 


4 


3 


2 


1 





* 


* 


ED5 


ED4 


ED3 


ED2 


ED1 


EDO 



7 


6 


5 


4 


3 


2 1 





* 


* 


* 


* 


CRDF 


CTDE CROE 


CTUE 



READ-ONLY 

CODEC 

RECEIVE DATA 

REGISTER 
(Addr X:$FFE9) 

WRITE-ONLY 

CODEC 

TRANSMIT DATA 

REGISTER 

(Addr X:$FFE9) 



READ-WRITE 
CODEC CONTROL 
REGISTER (CCR1) 
ADDRESS $FFC8 



READ-WRITE 
CODEC CONTROL 
REGISTER (CCRO) 
ADDRESS $FFC7 



READ-ONLY 

STATUS 

REGISTER (COSR) 

ADDRESS $FFE8 



reserved bits, read as zero, should be written with zero for future compatibility. 
Figure 6-4 On-chip Codec Programming Model 
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6.5.3 Codec Receive Register CRX 

The CRX Codec Receive register is used for A/D to DSP core data transfers. The CRX 
register is viewed as a 1 6-bit read-only register by the DSP core. The CRX register is load- 
ed with 1 6-bit data from the A/D section comb filter output. This transfer operation sets the 
CRDF bit in the codec status register COSR. Reading CRX clears CRDF. CRDF assertion 
will generate an interrupt if the COIE bit is set by the user. 

6.5.4 Codec Transmit Register CTX 

The CTX Codec Transmit register is used for DSP core to D/A data transfers. The CTX 
register is viewed as a 1 6-bit write-only register by the DSP core. Writing the CTX register 
clears the CTDE bit in the codec status register COSR. CTDE assertion will generate an 
interrupt if the COIE bit is set by the user. 

6.5.5 Codec Control Register CCRO 

The Codec Control register CCRO is a 1 6-bit read/write register used to direct the on-chip 
codec operation. The CCRO controls the clocking scheme and decimation/interpolation 
ratio of the codec. The CCRO bits are described in the following sections. 

All of the CCRO bits are cleared by DSP hardware and software reset. 

6.5.5.1 CCRO input Divider Bits (ED5-ED0) Bits 0-5 

The six input divider bits are used to divide the input clock to the codec by any number 
between 1 and 64. If ED is the value contained in the six bits, the input clock is divided by 
ED+1. 

Care should be taken to remain in the Codec operating range between "lOOKHz and 3 
MHz. 

Note: When the CLS bit is set in the CCR1 register (PLL output selected as input clock), 
the value programmed in the ED divider should be greater than 1 (minimum 2) 
for proper codec operation. 

6.5.5.2 CCRO Codec Ratio Select Bits (CRS5-0) Bits 13-8 

The Codec Ratio Select bits are used by the DSP core to program the decimation and 
interpolation ratio of the codec comb filter. The ratio values available are given in Figure 
6-13. 
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Tg 


ible 6-2 Decimation/Interpolation 


Ratio Control 


CRS5-CRS0 


Decimation 

Interpolation 

Ratio Rate 


A/D Comb Filter 
DC Gain 


D/A Comb Filter 
DC Gain 


$00 


65 


4(65 3 )/2 21 


-5.617 dB 


65/128 


-5.886 dB 


$01 


66 


4(66 3 )/2 21 


-5.219 dB 


66/128 


-5.753 dB 


$02 


67 


4(67 3 )/2 21 


-4.827 dB 


67/128 


-5.622 dB 


$03 


68 


4(68 3 )/2 21 


-4.441 dB 


68/128 


-5.494 dB 


$04 


69 


4(69 3 )/2 21 


-4.060 dB 


69/128 


-5.367 dB 


$05 


70 


4(70 3 )/2 21 


-3.686 dB 


70/128 


-5.242 dB 


$06 


71 


4(71 3 )/2 21 


-3.31 6 dB 


71/128 


-5.119 dB 


$07 


72 


4(72 3 )/2 21 


-2.951 dB 


72/128 


-4.998 dB 


$08 


73 


4(73 3 )/2 21 


-2.592 dB 


73/128 


-4.877 dB 


$09 


74 


4(74 3 )/2 21 


-2.237 dB 


74/128 


-4.759 dB 


$0A 


75 


4(75 3 )/2 21 


-1 .887 dB 


75/128 


-4.643 dB 


$0B 


76 


4(76 3 )/2 21 


-1 .542 dB 


76/128 


-4.527 dB 


$0C 


77 


4(77 3 )/2 21 


-1.202dB 


77/128 


-4.41 4 dB 


$0D 


78 


4(78 3 )/2 21 


-0.866 dB 


78/128 


-4.302 dB 


$0E 


79 


4(79 3 )/2 21 


-0.534 dB 


79/128 


-4.192 dB 


$0F 


80 


4(80 3 )/2 21 


-0.206 dB 


80/128 


-4.082 dB 


$10 


81 


4(81 3 )/2 21 


0.118dB 


81/128 


-3.974 dB 


$11 


82 


4(82 3 )/2 21 


0.437 dB 


82/128 


-3.868 dB 


$12 


83 


4(83 3 )/2 21 


0.753 dB 


83/128 


-3.763 dB 


$13 


84 


4(84 3 )/2 21 


1 .065 dB 


84/128 


-3.659 dB 


$14 


85 


4(85 3 )/2 21 


1 .374 dB 


85/128 


-3.558 dB 


$15 


86 


4(86 3 )/2 21 


1 .678 dB 


86/128 


-3.454 dB 


$16 


87 


4(87 3 )/2 21 


1 .980 dB 


87/128 


-3.354 dB 


$17 


88 


4(88 3 )/2 21 


2.277 dB 


88/128 


-3.254 dB 


$08 
$09 


72 
73 


125 3 /2 21 
1 


-0.61 8 dB 
OdB 


125/128 
1 


-0.206 dB 
OdB 


$0A 


74 


2(105 3 )/2 21 


0.859 dB 


105/128 


-1 .720 dB 


$0B 


75 


2(81 3 )/2 21 


0.118dB 


81/128 


-3.974 dB 


$0C 
$0D 


76 
77 


125 3 /2 21 
1 


-0.61 8 dB 
OdB 


125/128 
1 


-0.206 dB 
OdB 


$0E 


78 


2(105 3 )/2 21 


0.859 dB 


105/128 


-1.720dB 


$0F 


79 


2(81 3 )/2 21 


0.118dB 


81/128 


-3.974 dB 
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Table 6-2 Decimation/Interpolation Ratio Control - continued 


CRS5-CRS0 


Decimation 


A/D Comb Filter 


D/A Comb Filter 




interpolation 


DC Gain 


DC Gain 




Ratio Rate 










$18 


89 


2(89 3 )/2 21 


-3.449 dB 


89/128 


-3.156 dB 


$19 


90 


2(90 3 )/2 21 


-3.157dB 


90/128 


-3.059 dB 


$1A 


91 


2(91 3 )/2 21 


-2.869 dB 


91/128 


-2.963 dB 


$1B 


92 


2(92 3 )/2 21 


-2.584 dB 


92/128 


-2.868 dB 


$1C 


93 


2(93 3 )/2 21 


-2.303 dB 


93/128 


-2.774 dB 


$1D 


94 


2(94 3 )/2 21 


-2.024 dB 


94/128 


-2.682 dB 


$1E 


95 


2(95 3 )/2 21 


-1 .748 dB 


95/128 


-2.590 dB 


$1F 


96 


2(96 3 )/2 21 


-1 .476 dB 


96/128 


-2.499 dB 


$20 


97 


2(97 3 )/2 21 


-1 .206 dB 


97/128 


-2.409 dB 


$21 


98 


2(98 3 )/2 21 


-0.938 dB 


98/128 


-2.320 dB 


$22 


99 


2(99 3 )/2 21 


-0.674 dB 


99/128 


-2.231 dB 


$23 


100 


2(100 3 )/2 21 


-0.412 dB 


100/128 


-2.144 dB 


$24 


101 


2(101 3 )/2 21 


-0.153 dB 


101/128 


-2.058 dB 


$25 


102 


2(102 3 )/2 21 


0.104 dB 


102/128 


-1.972dB 


$26 


103 


2(103 3 )/2 21 


0.358 dB 


103/128 


-1 .887 dB 


$27 


104 


2(104 3 )/2 21 


0.61 OdB 


104/128 


-1 .804 dB 


$28 


105 


2(105 3 )/2 21 


0.859 dB 


105/128 


-1 .720 dB 


$29 


106 


2(106 3 )/2 21 


1.106 dB 


106/128 


-1 .638 dB 


$2A 


107 


2(107 3 )/2 21 


1.351 dB 


107/128 


-1 .556 dB 


$2B 


108 


2(108 3 )/2 21 


1 .593 dB 


108/128 


-1 .476 dB 


$2C 


109 


2(109 3 )/2 21 


1 .833 dB 


109/128 


-1 .396 dB 


$2D 


110 


2(110 3 )/2 21 


2.072 dB 


110/128 


-1.316dB 


$2E 


111 


2(111 3 )/2 21 


2.307 dB 


111/128 


-1 .238 dB 


$2F 


112 


2(112 3 )/2 21 


2.541 dB 


112/128 


-1.160 dB 


$30 


113 


(113 3 )/2 21 


-3.248 dB 


113/128 


-1 .083 dB 


$31 


114 


(114 3 )/2 21 


-3.01 8 dB 


114/128 


-1 .006 dB 


$32 


115 


(115 3 )/2 21 


-2.791 dB 


115/128 


-0.930 dB 


$33 


116 


(116 3 )/2 21 


-2.565 dB 


116/128 


-0.855 dB 


$34 


117 


(117 3 )/2 21 


-2.341 dB 


117/128 


-0.780 dB 


$35 


118 


(118 3 )/2 21 


-2.120 dB 


118/128 


-0.707 dB 


$36 


119 


(119 3 )/2 21 


-1.820dB 


119/128 


-0.633 dB 


$37 


120 


(120 3 )/2 21 


-1.682dB 


120/128 


-0.561 dB 


$38 


121 


(121 3 )/2 21 


-1 .465 dB 


121/128 


-0.488 dB 


$39 


122 


(122 3 )/2 21 


-1 .251 dB 


122/128 


-0.41 7 dB 


$3A 


123 


(123 3 )/2 21 


-1.039dB 


123/128 


-0.346 dB 


$3B 


124 


(124 3 )/2 21 


-0.827 dB 


124/128 


-0.258 dB 


$3C 


125 


(125 3 )/2 21 


-0.61 8 dB 


125/128 


-0.206 dB 


$3D 


126 


(126 3 )/2 21 


-0.41 OdB 


126/128 


-0.137 dB 


$3E 


127 


(127 3 )/2 21 


-0.204 dB 


127/128 


-0.068 dB 


$3F 


128 


1 


OdB 


1 


OdB 



As shown in Figure 6-13, the value selected as decimation and interpolation ratio also af- 
fects the DC gain of the comb filter in the A/D and D/A sections. The global DC gain of the 
A/D and D/A sections is discussed in detail in Section 6.6. 
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6.5.5.3 CCRO Reserved Bits 6-7 and 14-15 

These bits are reserved. They should be written as zero by the user program to insure 
future compatibility. 

6.5.6 Codec Control Register CCR1 

The Codec Control Register CCR1 is a 16-bit read/write register used to direct the oper- 
ation of the on-chip codec. The CCR1 controls the receive and transmit audio gains, the 
codec clocking source, the selection of the analog input, the muting of the analog output, 
the codec power down, the codec enable, and the codec interrupt enable. The CCR1 bits 
are described in the following sections. 

All of the CCR1 bits are cleared by DSP hardware and software reset. 

6.5.6.1 CCR1 Audio Level Control Bits (VC3-VC0) Bits 0-3 

Audio gain control is employed in the last stage of the on-chip codec D/A section. Bits 
VC0-VC3 control the volume between -15 dB and 40 dB as shown in Figure 6-13. 

Table 6-3 Audio Level Control 











Relative Level 


VC3 


VC2 


VC1 


vco 


indB 














-15 











1 


-10 








1 





-5 








1 


1 








1 








5 





1 





1 


11 





1 


1 





17 





1 


1 


1 


23 


1 











5 


1 








1 


11 


1 





1 





17 


1 





1 


1 


23 


1 


1 








29 


1 


1 





1 


35 


1 


1 


1 





35 


1 


1 


1 


1 


40 



■* 



A 1 6-bit full scale positive value of $7FFF written to the D/A should produce a voltage level 
equal to Vrda = +1 Vp singled-ended and Vrda = +2Vp differential at the output when the 
volume control bits VC3-VC0 are set to the level of dB and when the DC gain of the D/ 
A comb filter is unity (decimation ratio of 128). 

The digital reconstruction-interpolation filter performed by the DSP core can also be used 
to control the output audio level in conjunction with the four VC3-VC0 bits. The gain of this 
filter can be adjusted in order to modify the relative level and the step between levels. Ta- 
ble 6-4 gives an example where the gain of the interpolation digital filter is adjusted in or- 
der to provide output volume control between -1 5dB and +40dB in 5dB steps. 
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Table 6-4 Audio Level Control with DSP Filter Gain 


VC3 


VC2 VC1 VCO 


Relative Level 


Digital Filter 


Final Output 






dB 


Gain 


Level 








-15 





-15 





1 


-10 





-10 





1 


-5 





-5 





1 1 














1 


5 





5 





1 1 


11 


-1 


10 





1 1 


17 


-2 


15 





1 1 1 


23 


~3 


20 


1 





5 





5 


1 


1 


11 


-1 


10 


1 


1 


17 


-2 


15 


1 


1 1 


23 


-3 


20 


1 


1 


29 


-4 


25 


1 


1 1 


35 


-5 


30 


1 


1 1 


35 





35 


1 


1 1 1 


40 





40 



6.5.6.2 CCR1 Codec Loop Back Bit (CLB) Bit 7 

The Codec Loop Back Bit selects the input to the analog back end of the DAC. This bit is 
cleared for normal DAC operation. When CLB is set, the output of the A/D analog modu- 
lator is used as input to the analog back end of the DAC, as shown in Figure 6-2. 

6.5.6.3 CCR1 Clock Select Bit (CLS) Bit 8 

This bit is used to select the source of the codec clock. When the CLS bit is cleared, the 
squared version of Fext is selected as the codec clock input. When this bit is set, the codec 
input clock is derived from the PLL output, as shown in Figure 6-2. 

Note: When CLS is set, the value programmed in the ED divider should be greater than 
one (minimum two) for proper codec operation. 



6.5.6.4 CCR1 Mute Bit (MUT) Bit 10 

The mute bit is used to mute the output signal. When the MUT bit is cleared, the output 
signal is muted. When the MUT bit is set, the output signal is not muted. 

6.5.6.5 CCR1 Microphone Gain Select Bits (MGS1-Q) Bits 11 and 12 

The Microphone Gain Select Bits are used by the DSP core to program the analog input 
gain. The values are given in Table 6-5. The analog modulator is guaranteed to be linear 
up to 3 dB below full scale saturation values. The full scale saturation analog value results 
in a maximum digital A/D output ($7FFF) when the A/D comb filter has a DC unity gain. 
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Table 6-5 Microphone Gain Control 






MGS1 MGSO 


Gain 
Actual dB 


Modulator 
full scale 


Full scale 
linearity 








1 

1 

1 1 


0.5 

1 

2 
7.07 


-6 

6 
17 


2Vp 

1 Vp 

500 mVp 

141 mVp 


1.414Vp 
0,707 Vp 
354 mVp 
100mVp 





6.5.6.6 CCR1 Input Select Bit (INS) Bit 13 

The input select bit is used by the DSP to select between the two inputs — MIC and AUX. 
When INS is cleared, MIC is selected and when INS is set, the AUX input is selected. 

6.5.6.7 CCR1 Codec Enable Bit (COE) Bit 14 

The Codec Enable Bit enables the on-chip codec section. When this bit is cleared, the 
section is disabled and put in the power down mode. Setting the bit wakes-up and enables 
the on-chip codec section. 

6.5.6.8 CCR1 Codec Interrupt Enable Bit (COIE) Bit 15 

The Codec Interrupt Enable Bit enables the on-chip codec interrupt. When this bit is 
cleared the interrupt is disabled. Setting the bit enables the interrupt. 

6.5.6.9 CCR1 Reserved Bits 4,5,6, and 9 

These bits are reserved. They should be written as zero by the user program to insure fu- 
ture compatibility. 

6.5.7 Codec Status Register COSR 

The Codec Status Register COSR is an 8-bit read-only status register used by the DSP 
to interrogate the status and flags of the on-chip codec. The status bits and flag bits are 
described in the following paragraphs. 

6.5.7.1 COSR Codec Transmit Underrun Error FLag Bit (CTUE) Bit 

The Codec Transmit Underflow Error Flag Bit is set when a sample has to be transmitted 
to the codec section while the DSP has not yet written to the CTX transmit register (un- 
derrun error). In this case, the previous sample written to the CTX register is re-transmit- 
ted to the D/A section. 

Hardware or software reset and the STOP instruction clear CTUE. CTUE is also cleared 
by reading the COSR with CTUE set followed by writing CTX. Clearing the COE bit in the 
Codec Control Register CCR1 does not affect CTUE. 
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6.5.7.2 COSR Codec Receive Overrun Error Flag Bit (CROE) Bit 1 

The Codec Receive Overrun Error Flag bit is set when a new sample is received from the 
codec section while the previous received sample in the CRX receive register has not 
been read by the DSP (overrun error). In this case 5 the previous received sample is over- 
written in the CRX register. 

Hardware or software reset and the STOP instruction clear CROE. CROE is also cleared 
by reading the COSR with CROE set followed by reading CRX. Clearing the COE bit in 
the Codec Control Register CCR1 does not affect CTUE. 

6.5.7.3 COSR Codec Transmit Data Empty Bit (CTDE) Bit 2 

The Codec Transmit Data Empty (CTDE) bit indicates that the D/A Transmit register CTX 
is empty and can be written by the DSP. CTDE is set when the CTX register is transferred 
to the D/A comb filter input. CTDE is cleared when the CTX register is written by the DSP. 
CTDE is also set entering the codec power down mode (COE cleared) and by a DSP reset 
(Hardware RESET or RESET instruction) and the STOP instruction. 

6.5.7.4 COSR Codec Receive Data Full Bit (CRDF) Bit 3 

The Codec Receive Data Full (CRDF) bit indicates that the A/D Data Receive register 
CRX contains data from the codec A/D section. CRDF is set when data is transferred from 
the A/D comb filter output to the CRX register. CRDF is cleared when the CRX Register 
is read by the DSP. CRDF is also cleared entering the Codec power down mode (COE 
cleared), by a DSP reset (Hardware RESET or RESET instruction) and the STOP instruc- 
tion. 

6.5.7.5 COSR Reserved Bits 4-15 

These bits are reserved. They will be read as zeros by the user program. 
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On-chip Codec Status Registers (COSR X:$FFE8) 

7 6 5 4 3 2 1 



CRDF CTDE CROE CTUE 



CRDF 
(read-only) 



CTDE 
(read-only) 



CROE 
(read-only) 



CTUE 
(read-only) 



Data From A/D not received in CRX 



Data From A/D received in CRX 



Data in CTX has not been transferred to D/A 



CTX empty 



No Receive Overrun Error 



Receive Overrun Error 



No Transmit Underrun Error 



Transmit Underrun Error 



On-chip Codec Control (CCR1) X:$FFC8 



15 14 13 



COIE 



COE 



INS 



MGS1-0 
Gain Select 



MUT 



CLS 



CLB 



VC3VC0 
D/A output 
Gain in dB 



12 



11 



10 



111 



-L 



hL 



± 



1 



_l 



00 



01 



$0 



$2 



$3 



_M_ 



$5 



IT 



Codec interrupt disab led 



Codec interrupt enabled 



Codec disabled and put in power down 



Codec enabled 



MIC pin selected as A/D input 
AUX pin selected as A/D input 



MIC or AUX amplifier gain of -6dB 



MIC or AUX amplifier gain of OdB 



MIC or AUX amplifier gain of 6dB 



MIC or AUX amplifier gain of 1 7dB 



Speake r output muted 



Speaker output active 



Squared Fext selected as codec input clock 



PLL block output selected as codec input clock 



Normal Codec operation 



The input of the D/A digital modulator is the output of the A/D modulator 



-15 dB Output volume gain 



-1 dB Output volume gain 



-5 d B Out put volu me gain 



dB Ou tput volume gain 



5 dB Output volume gain 



1 1 dB Output volume gain 



17 dB Output volume gain 



23 dB~C 7 utput volume gain 



$8 



$9 



$A 



$B 



$C 



$D 



$E 



~W~ 



5 dB Output volume gain 



1 1 dB Output volume gain 



1 7 dB Output volume gain 



23 dB Output volume gain 



29 dB Output volume gain 



35 dB Output volume gain 



35 dB Output volume gain 



"40 dB Output volume gam 



D 



15 


14 




13 


12 


11 


10 


9 




8 


n-chip 

7 


>Coc 

6 


iec Contro 

5 4 


(CCF 

3 


10) X:$! 

2 


=FC7 

1 









































CRS0-5 


$0-$3F 


Continuous ratio from 65 to 128 
(see Table 6-2) 


ED0-5 


$0-$3F 


Codec Clock Division from 
1 to 64 



Figure 6-5 On-Chip Codec Programming Model Summary 
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6.6 ON-CHIP CODEC GAIN AND FREQUENCY RESPONSE ANALYSIS 

This section discusses the DC gain and the frequency response of the A/D and D/A blocks 
as a function of the decimation and interpolation ratios. 

6.6.1 DC Gain and Frequency Response of the A/D Section 

The DC gain and the frequency response of the A/D comb filter depends on the decima- 
tion rates selected by programming the six bits CRS5-CRS0 in the codec control register 
CCRO. The decimation rate can take any values between 65 and 1 28. A negative DC gain 
is introduced by scaling inside the comb filter in order to avoid any signal clipping caused 
by a positive DC gain of the comb filter itself. The A/D comb filter gains are given in Figure 
6-13. 

The digital output level out of the A/D section can be normalized to dB or to any other 
value by changing the gain of the last decimation/antialiasing filter performed by the DSP 
core program. In addition to filtering and decimating, this last digital filter can also com- 
pensate the frequency response of the A/D comb filter. 

The comb filter is a linear phase filter constructed as a cascade of digital integrators and 
differentiators which realizes the transfer function and frequency response of Figure 6-13. 



H(z) = 



128° 



-,3 



--D 



1 -z~ 



sin(-~^ xf) 



F(f) = 



128° 



2F 



sm(^-xf) 



c=4 for D=[65,88] 
c=2forD=[89,112] 
c=1 for D=[1 12,128] 
D: decimation ratio 
F: modulator clock 



Figure 6-6 A/D Comb Filter Transfer Function 

The cubic power is due to the order. The comb filter is ideal for decimation applications 
because it has zeros at the final output clock rate and all its multiples. 

Figure 6-7 and Figure 6-8 show an example of the log magnitude response of the A/D 
comb filter using a master clock of 2.048 MHz and a decimation ratio of D=128. 
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Figure 6-7 Log Magnitude Frequency Response of the 
A/D Comb Filter for F=2.048 MHz and D=128 
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These figures show the frequency response in the 0-1.024 MHz band and also the fre- 
quency response after decimation in the 0-16KHz and 0-4KHz bands. 
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Figure 6-8 Log Magnitude Frequency Response of the 
A/D Comb Filter in the Band 0-4 KHz for F=2.048 MHz and D=128 

The output of the decimating comb filter is a 2's complement 1 6-bit word at the decimated 
rate which goes to the DSP core. It is hard limited to the range $8000-$7FFF to prevent 
roll over error. Figure 6-8 gives the frequency response of the A/D section in the 0-4KHZ 
band. It can be seen that this response is not flat in the band. The 3 dB drop-off can be 
compensated by the decimation filter inside the DSP core. The transfer function of the A/ 
D comb is given on Figure 6-13 

It is equal to: 



F(f) = 



128° 



sin(— xf) 
sin(^xf) 
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In the present example, D=128, c=1 and F=2.048 MHz, which gives: 



F(f) = 



( . , 2ti x 1 28 \ 

S m( X f) 

v 2x 2.048 



(128) c 



sin ( 



271 



2x2.048 



xf) 



The transfer function of the decimation filter will have to be shaped by 1/F(f) in order to 
flatten the response of the A/D section. 

Table 6-6 gives a 4 biquad MR low pass filter who's transfer function has been shaped ac- 
cordingly. 

Figure 6-9 shows the frequency response of the filter and the effects on the overall re- 
sponse of the D/A section. 

Table 6-6 Example of a Four Biquad 1IR Decimation and Compensation Filter 




; Source filter file: tt adcomp128.IIR. Filter" 




Jilter_type equ BIQUAD_FILTER_TYPE 


_NSTAGES equ 4 


; number of stages 


dc $02b2 


; gain = 0.0421 1689868/2 


; Biquad stage no. 1 
dc -$1237 


; d2_1 = 0.284627003/2 


dc $e93c 


;d1_1 =-0.3557032662/2 


dc $31 6a 


; n2_1 = 0.7720730807/2 


dc $4186 


;n1_1 =1.023796768/2 


; Biquad stage no. 2 
dc -$28f8 


;d2_2 = 0.6401634264/2 


dc $e8df 


;d1_2 = -0.3613604173/2 


dc $0d0c 


; n2_2 = 0.2038857781/2 


dc $12dc 


;n1_2 = 0.2946510536/2 


; Biquad stage no. 3 
dc -$0c66 


;d2_3 = 0.1937047354/2 


dc $d60d 


;d1_3 = -0.6554721197/2 


dc $3454 


;n2_3 = 0.8176134701/2 


dc $4328 


;n1_3= 1.049344022/2 


; Biquad stage no. 4 
dc -$3951 


;d2_4 = 0.8955455145/2 


dc $f4e3 


;d1_4 = -0.1736521771/2 


dc $2ed3 


;n2_4 = 0.7316442217/2 


dc $1b24 


;n1_4 = 0.42404578/2 


NOTE: This filter, as well as all the figures representing filter re- 
sponses, has been generated using ZOLA Technologies, 
Inc., DSP Designer™ software package. 
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Figure 6-9 IIR Decimation and A/D Section Log Magnitude Frequency Response 

for F=2.048 MHz and D=128 
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6.6.2 DC Gain and Frequency Response of the D/A Section 

The DC gain and the frequency response of the D/A section depend on the interpolation 
rates selected by programming the six bits CRS5-CRS0 in the codec control register 
CCRO. The interpolation rate can take any value between 65 and 128. 

The D/A comb filter gains are given in Figure 6-13. 

The D/A section of the on-chip codec is composed of three subsections which are de- 
scribed below. 

The frequency responses of the different sections of the D/A are illustrated in Figure 6-1 0. 



CD 

o 

3 



0» 

3 



D/A Comb Filter Response 
D/A A nalog LP Filter Response - 

. [ r— p 




400 600 

Frequency (KHz) 



1024 



Figure 6-10 Log Magnitude Frequency Responses of the 
Three Sections of the D/A F=2048 MHz and D=128 

6.6.2.1 D/A Second Order Digital Interpolation Comb Filter 

The parallel interface of the D/A section receives a 2's complement 1 6-bit word from the 
DSP core at the initial data rate. The interpolating comb filter is a second order digital 
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comb filter. It is a linear phase filter that provides interpolation and anti-imaging on the in- 
put to the digital modulator. The comb filter is constructed as a sample and hold stage fol- 
lowed by a cascade of a digital differentiator and integrator which realizes the transfer 
function and the frequency response given in Figure 6-1 1 . 



H(z) 



1 



128D 



1 -z" 



1 -z~ 



F(f) = 



1 



128D 



f - ,2710 x 
sin(--^xf) 

sinC—^xf) 



D: interpolation ratio 
F: comb filter integrator clock 



Figure 6-11 D/A Comb Filter Transfer Function 

The power of two is due to the order of the filter. The comb filter is ideal for interpolation 
applications because it has zeros at the initial data rate and all its multiples. 

Figure 6-1 2 shows an example of the log magnitude response of the D/A digital comb filter 
using a master clock of 2.048 MHz and a decimation ratio of D=1 28. The figure shows the 
frequency response of the comb filter in the 0-1024KHz band and also after decimation 
(0-16KHz). 
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Figure 6-12 Log Magnitude Frequency Response of the 
D/A Comb Filter for F=2.048MHz and D=128 
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6.6.2.2 D/A Digital Modulator 

The digital modulator is a second-order sigma-delta loop. It is made up of two digital inte- 
grators, a digital comparator, and a hard limit circuit. The output of the modulator is a 1- 
bit stream which contains the input signal plus a large amount of quantization noise which 
is shaped away from the baseband and towards the high frequencies. This 1-bit stream 
is then filtered by the analog low pass filter. 

When the Codec Loop Back bit (CLB) of CCR1 is set, the input for the digital modulator 
is the output of the analog modulator of the A/D section. 

6.6.2.3 D/A Butterworth Analog Low Pass Filter 

The analog low-pass filter is a two-pole Butterworth switched capacitor filter. The purpose 
of this filter is to attenuate the out-of-band quantization noise and the images created by 
the upsampling. 

Figure 6-13 gives the transfer function of the filter: 



H(z) = 



(0.0003506002) 



(1 - 1.973345z" 1 +0.9736956z~ 2 ) 



Figure 6-13 Analog Low-pass Filter Transfer Function 

Figure 6-14 shows the log magnitude response of the D/A analog low-pass filter. The fig- 
ures show the frequency response of the filter in the 0-256KHz, 0-20KHz, 0-8KHz, and 0- 
4KHz bands. 
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Figure 6-14 Log Magnitude Frequency Response of the 
D/A Analog Low-pass Filter for F=2.048MHz 

6.6.2.4 Overall Frequency Response of the D/A Section 

Figure 6-15 shows the D/A frequency response in the 0-1 28KHz band. Figure 6-1 6 shows 
the overall frequency response of the D/A section in the 0-16KHz and 0-4KHz bands. 
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Figure 6-15 Log Magnitude Frequency Response of the 
D/A Section for F=2.048 MHz and D=128 

It can be noted in Figure 6-1 6b that the frequency response is not flat in the 0-4KHz band. 
The interpolation filter performed by the DSP core can compensate for this droop in am- 
plitude caused by the D/A hardware section. 

The digital second order D/A comb filter is the only filter that needs to be compensated. 
Its transfer function is given in Figure 6-13. 

It is equal to: 



F(f) = 



128D 



sin(-^-xf) 
sin(^xf) 
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Figure 6-16 Log Magnitude Frequency Response of the 
D/A Section for F=2.048 MHz and D=128 
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In the present example, D=128 and F=2048 MHz, which gives: 



F(f) = 



f . 2tix128 x 

sin (- — — — xf) 

2 x 2048 



(128)' 



sin ( 



271 



2 x 2048 



xf) 



The transfer function of the interpolation filter will have to be shaped by 1/F(f) in order to 
flatten the response of the D/A section. 

Table 6-7 gives a 4 biquad MR low pass filter who's transfer function has been shaped ac- 
cordingly. 

Figure 6-17 shows the frequency response of the filter and the effects on the overall re- 
sponse of the D/A section. 

Table 6-7 Example of a Four Biquad IIR Interpolation and Compensation Filter 



; Source filter file: "compl 282nd. IIR. Filter" 


filter type equ BIQUAD 


FILTER TYPE 


_NSTAGES equ 4 


; number of stages 


dc $0270 


; gain = 0.03807147513/2 


; Biquad stage no. 1 




dc -$18de 


;d2_1 =0.3885309315/2 


dc $e920 


; d1_1 = -0.3574372286/2 


dc $329e 


; n2_1 = 0.7908895273/2 


dc $43d3 


;n1_1 =1.059754603/2 


; Biquad stage no. 2 




dc -$26b9 


; d2_2 = 0.6050537737/2 


dc $ec15 


;d1_2 = -0.31 12185033/2 


dc $1014 


;n2_2 = 0.2512476586/2 


dc $1146 


;n1_2 = 0.269897941 1/2 


; Biquad stage no. 3 




dc -$0e57 


; d2_3 = 0.2240856408/2 


dc $cf53 


;d1_3 = -0.7605800752/2 


dc $3603 


; n2_3 = 0.8439490258/2 


dc $4614 


;n1_3 = 1.094956692/2 


; Biquad stage no. 4 




dc -$38d6 


;d2_4 = 0.8880624617/2 


dc $f59a 


;d1_4 = -0.162456827/2 


dc $2f25 


; n2_4 = 0.7366593399/2 


dc $1c8f 


; n1_4 = 0.4462262322/2 


NOTE: This filter, as well as all the figures representing filter re- 


sponses, has been generated using ZOLA Technologies, 


Inc., DSP Designer™ software package. 
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Figure 6-17 IIR Interpolation and D/A Section Log Magnitude Frequency Response 

for F=2.048 MHz and D=128 



MOTOROLA DSPS6166 ON-CHIP SIGMA/DELTA CODEC 



t:$f|lil|f 



Illlll 


ON-CHIP CODEC GAIN AND FREQUENCY RESPONSE ANALYSIS 


Illlll 





Illlll 



DSP561 66 ON-CHIP SIGMA/DELTA CODEC MOTOROLA 



SECTION 7 



16-BIT TIMER AND EVENT COUNTER 




MM 



^^tTTMWES'M^ 



ItyfOFtdLA 



SECTION CONTENTS 



7.1 INTRODUCTION . . . . 

7.2 TIMER ARCHITECTURE 

7.3 TIMER COUNT REGISTER (TCTR) 

7.4 TIMER PRELOAD REGISTER (TPR) .... 

7.5 TIMER COMPARE REGISTER (TCPR) .. 

7.6 TIMER CONTROL REGISTER (TCR) .... 

7.6.1 . TCR Decrement Ratio (DC7-DC0) Bits 0-7 

7.6.2. TCREv@ritSefecl(ES)Bit8 

7.6.3. TCR Overflow Interrupt Enable (OIE) Bit 9 

7.6.4. TCR Compare Interrupt Enable (ClE) Bit 1 D 

7.6.5. TCR Tinier Output Enable (TO2-TO0) Bits 1 1 

7.6.6. TCR Inverter Bit <INV) Bit 1 4 

7.6.7. TCR Timer Enable fTE) Bit 1 5 . , 

7.7 TIMER RESOLUTION , 

7.8 FUNCTIONAL DESCRIPTION OF THE TIMER 



■I 



7-3 
7-3 

nil 

7-4 

liil 
liil 

7-6 
7-6 
7-6 
7*7 

7-7 

liil 

7-8 
7-8 



■ill 



*taifct»ite«:$^ 



MOTOROLA: 



llillilliiliil 



7.1 INTRODUCTION 

This section describes a general purpose 16-bit timer/event counter with either internal 
clocking to count internal events or external clocking to count external events. This timer/ 
event counter can be used to either interrupt the DSP or to signal an external device at 
periodic intervals. A Timer Input pin (TIN) can be used as an event counter input and a 
Timer Output pin (TOUT) can be used as a timer pulse or for timer clock generation. 

7.2 TIMER ARCHITECTURE 

Figure 7-1 shows the general block diagram of the timer. It includes three 1 6-bit registers: 
the Timer Count Register (TCTR), the Timer Preload Register (TPR), and the Timer Com- 
pare Register (TCPR). An additional Timer Control Register (TCR) controls the timer op- 
erations. 

A decrement register, programmed by the control register, is not available to the user. All 
other registers are read/write registers memory mapped as shown in Figure 7-2. 

7.3 TIMER COUNT REGISTER (TCTR) 

When the timer is enabled (TE=1), the 16-bit timer count register is decremented by one 
after the decrement register has reached the value zero. On the next event after the count 
register reaches the value zero, an overflow interrupt will be generated if the Overflow In- 
terrupt Enable bit (OIE) is set in the timer control register. Also, the state of the TOUT pin 
can then be affected according to the mode selected by the Timer Out Enable bits (T02- 
TOO) of the timer control register. If n is the value stored in the count register when the 
timer is enabled, the overflow interrupt occurs after (n+1)*(DC+1) input events, DC being 
the preset value of the decrement register. After reaching zero, the count register is re- 
loaded with the contents of the preload register or with a direct value if a direct write to the 
count register had been executed after the last timer count register reload. 

On the next event after the count register reaches the value of the compare register, a 
compare interrupt is generated if the Compare Interrupt Enable bit (CIE) is set in the timer 
control register. The state of the TOUT pin may also be affected according to the mode 
selected by the Timer Out Enable bits (TO2-TO0) of the timer control register. 

The user program can write a new value into the count register anytime. If the timer is en- 
abled (TE=1) during the write to the count register, this new value is written to the TCTR 
on the next count register decrement (next event after the decrement register reaches 
zero). If the timer is disabled (TE=0) during the write, the value is immediately written to 
the count register and will not be overwritten by the value stored in the preload register 
when the timer gets enabled (TE=1 ). In that case, the value stored or written in the preload 
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register will be loaded into the count register on the next event after it reaches zero, unless 
another write to the count register is performed in between. Refer to Section 7.8, Func- 
tional Description of the Timer, for more details. 



The count register is initialized to zero on hardware RESET and software reset (RESET 
instruction). 
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Figure 7-1 16-bit Timer General Block Diagram 

7.4 TIMER PRELOAD REGISTER (TPR) 

The preload register is a 1 6-bit read/write register which typically contains the value to be 
reloaded inside the count register when the timer is enabled and when the timer count reg- 
ister (TCTR) has been decremented to zero. 

If the timer is enabled (TE=1) when the user program writes a new value inside the pre- 
load register (TPR), this new value is transferred to the count register the next time the 
count register is loaded (after it reaches zero), unless a direct write to the count register 
is performed while the TCTR is zero. 
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If the timer is disabled (TE=0) when the user program writes a new value inside the pre- 
load register, this new value transfers immediately into the count register unless a direct 
write to the TCTR has already been performed. 



The preload register is initialized to zero by hardware RESET and software reset (RESET 
instruction). 
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Figure 7-2 Timer Programming Model 

7.5 TIMER COMPARE REGISTER (TCPR) 

The output compare register is a 16-bit read/write register used to program an action 
when the value of the count register reaches the value contained in the compare register. 
The value in the compare register is compared against the value of the count register on 
every instruction cycle. At the next event after the compare matches, an interrupt is gen- 
erated if interrupts are enabled (CIE=1) and the state of the TOUT pin changes according 
to the mode selected by the Timer Out Enable bits (TO2-TO0) of the timer control register. 
This is useful for providing a pulse width modulated timer output. 



The compare register is initialized to zero by hardware RESET and software reset (RE- 
SET instruction). 
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7.6 TIMER CONTROL REGISTER (TCR) 

The timer control register is a 1 6-bit read/write register that contains the control bits for the 
timer. The control bits are defined in the following paragraphs. 

READ/WRITE 

TIMER CONTROL 

REGISTER (TCR) 

ADDRESS X:$FFEC 

Figure 7-3 Timer Control Register 

7.6.1 TCR Decrement Ratio (DC7-DC0) Bits 0»7 

DC7-DC0 are eight clock divider bits that are used to preset an 8-bit counter which is dec- 
remented at the input clock rate. If DG7-DC0= n, n+1 clock cycles will be counted before 
decrementing the count register, i.e., the decrement register acts as a prescaler. The 8- 
bit decrement register is not accessible to the user. 

If the timer is disabled (TE=0) when a new value is written to this field, the decrement reg- 
ister will start decrementing with this initial value when the timer is enabled (TE=1). If the 
timer is enabled (TE=1) when a new value is written to this field, the decrement register 
will be reloaded with this value after it has reached the value zero. DC7-DC0 are reset to 
zero on hardware RESET and software reset (RESET instruction). 

7.6.2 TCR Event Select (ES) Bit 8 

The event select bit (ES) selects the source of the timer clock. If ES is cleared, Fosc/2 is 
selected as input of the decrement register. If ES is set, an external signal coming from 
the TIN pin is used as input to the decrement register. The external signal is synchronized 
to the internal clock and should be lower than the maximum internal frequency Fosc/4. ES 
is cleared by hardware RESET and software reset (RESET instruction). 

7.6.3 TCR Overflow Interrupt Enable (OIE) Bit 9 

The overflow interrupt has precedence over the compare interrupt at the same priority lev- 
el. A compare interrupt will remain pending until all pending overflow interrupts are ser- 
viced. When the Overflow Interrupt Enable bit (OIE) is set, the DSP will be interrupted at 
the next event after the count register reaches zero. When the OIE bit is cleared, this in- 
terrupt is disabled. OIE bit is cleared on hardware RESET and software reset (RESET in- 
struction). 
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7.6.4 TCR Compare Interrupt Enable (CIE) Bit 1 

When the Compare Interrupt Enable bit (CIE) is set, the DSP will be interrupted at the next 
event after the count register reaches the value contained in the compare register. When 
the CIE bit is cleared, this interrupt is disabled. The CIE bit is cleared on hardware RESET 
and software reset (RESET instruction). 

7.6.5 TCR Timer Output Enable (TO2-TO0) Bits 11-13 

The three timer output enable bits (TO2-TO0) are used to program the function of the tim- 
er output pin (TOUT). Table 7-1 shows the relationship between the value of TO2-TO0 
and the function of the TOUT pin. These bits are cleared on hardware RESET and soft- 
ware reset (RESET instruction). 

Table 7-1 TOUT Pin Function 
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Note: If one of the toggle modes is selected and TE is written as zero while the TOUT pin 
is either high or low, the pin remains in the same state. If the T02 bit is written as 
zero with the TE bit, the pin will remain high and will go low when the timer is re- 
enabled. Writing the T02 bit as zero before writing the TE bit as zero will clear the 
TOUT pin, i.e., in the non-toggle modes, TOUT is normally low. 

7.6.6 TCR inverter Bit (INV) Bit 1 4 

When the inverter bit INV is set, the external signal coming in the TIN pin is inverted before 
entering the 8-bit decrement register. All 1 to transitions of the TIN pin will then decre- 
ment the decrement register. When the INV bit is cleared, the external signal on TIN is not 
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Inverted and the decrement register is decremented on all to 1 transitions. INV is cleared 
on hardware RESET and software reset (RESET instruction). 

7.6.7 TCR Timer Enable (TE) Bit 15 

The TE bit is used to enable or disable the timer. Setting the TE bit will enable the timer. 
The decrement register will start decrementing from its preset value each time an event 
comes in. Clearing the TE bit will disable the timer. The decrement register will be preset 
to the value contained in bits DC7-DC0 of the control register and the count register will 
be loaded with the value of the preload register. However, if a direct write to the count reg- 
ister has happened since the last count register reload, the value written will be loaded 
into the count register instead of the preload value. TE is cleared by hardware RESET and 
software reset (RESET instruction). 

7.7 TIMER RESOLUTION 

Table 7-2 shows the range of timer interrupt rates (overflow interrupt using internal event, 
Fosc/2) that are provided by the 16-bit count register, the 16-bit preload register, and the 
8-bit decrement register. 

Table 7-2 Timer Range and Resolution 



ICycle Time 


DC7-DC0 value 


Interrupt Rate 
(Preload = 2 16 ) 


Resolution 
(Preload=0) 


33 ns 
(60MHZ-30 MIPS) 



255 


2.162 ms 
553.5 ms 


33 ns 
8.4 us 


51 ns 
(39MHZ-19.5MIPS)) 



255 


3.342 ms 
855.6 ms 


51 ns 
13.06 us 


74 ns 
(27MHZ-13.5MIPS) 



255 


4.85 ms 
1 .242 s 


74 ns 
18.94 us 



The overflow interrupt occurs every (PRELOAD+1)*(DC7-DC0+1) input clock cycles. 

7.8 EVENT COUNTER TIMER DIAGRAMS 

The figures given in this section illustrate most configurations in which the timer can be 
enabled, disabled, and used. 
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Figure 7-4 Standard Timer Operation with Overflow Interrupt 
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Figure 7-5 Standard Timer Disable 
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Write to the Count Register After Writing to the Preload Register 
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Figure 7-7 Timer Disable After a Write to the Count Register 
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Figure 7-8 Write to the Count Register when the Timer is Enabled 
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Figure 7-9 Write to DC7-DC0 when the Timer is Enabled 
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Figure 7-10 Standard Timer Operation with Compare Interrupt 
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8.1 INTRODUCTION 

The Reduced Synchronous Serial Interface (RSSI) is a full duplex serial port which allows 
the DSP to communicate with a variety of serial devices including one or more industry 
standard codecs, other DSPs, microprocessors, and peripherals. The RSSI interface con- 
sists of independent transmitter and receiver sections with a common RSSI clock gener- 
ator and frame synchronization. 

8.2 RSSI OPERATING MODES 

The RSSI has several basic operating modes. These modes can be programmed by sev- 
eral bits in the RSSI control registers.Table 8-1 . lists these operating modes and some of 
the typical applications in which they may be used: 

Table 8-1. RSSI Operating Modes 



TX, RX Sections 


Serial Clock 


Protocol 


Typical Applications 


Synchronous 


Continuous 


Normal 


Multiple Synchronous Codecs 


Synchronous 


Continuous 


Network 


TDM Codec or DSP Networks 


Synchronous 


Gated 


Normal 


SPI-Type Devices; DSP to MCU 


Synchronous 


Gated 


Network 


DSP to SPI peripherals 



The transmit and receive sections of this interface are synchronous; that is, the transmitter 
and the receiver use a common clock and frame synchronization signal. Continuous or 
gated mode may be selected. For continuous mode, the clock is continuously running and 
for gated mode the clock is only functioning during transmission. Normal or network pro- 
tocol may also be selected. For normal protocol, the RSSI functions with one data word 
of I/O per frame. For network protocol, any number from two to eight data words of I/O 
may be used per frame. These distinctions result in the basic operating modes which al- 
low the RSSI to communicate with a wide variety of devices. 

8.3 RSSI CLOCK AND FRAME SYNC GENERATION 

Data clock and frame sync signals can be generated internally by the DSP or may be ob- 
tained from external sources. If internally generated, the RSSI clock generator is used to 
derive bit clock and frame sync signals from the DSP internal system clock. The RSSI 
clock generator consists of a selectable, fixed prescaler and a programmable prescaler 
for bit rate clock generation. For gated clock mode, the data clock will be valid only when 
data is to be transmitted, otherwise the clock pin will be three-stated. A programmable 
frame rate divider and a word length divider are used for frame rate sync signal genera- 
tion. For gated mode, no frame sync signal is used. 
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8.4 RSSI DATA AND CONTROL PINS 

The RSSI has four dedicated I/O pins: 

• Transmit data STDx (PCO for RSSIO and PCS for RSSI1) 

• Receive data SRDx (PC1 for RSSIO and PC6 for RSSI1) 

• Serial clock SCKx (PC2 for RSSIO and PC7 for RSSI1 ) 

• Serial frame sync SFS (PC4 for RSSIO and PC9 for RSSI1 ) 

Figure 8-1 through Figure 8-4 show the main RSSI configurations and the following para- 
graphs describe the uses of these pins for each of the RSSI operating modes. 
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Figure 8-1 RSSI Internal Continuous Clock 
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Figure 8-2 RSSI External Continuous Clock 
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Figure 8-3 RSSI Internal Gated Clock 
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Figure 8-4 RSSI External Gated Clock 

Figure 8-5 shows the internal clock path connections in block diagram form. The serial bit 
clock can be internal or external depending on the SCKD bit in the control register. 









PSR 

1 




PM0-PM7 

I 


















Foso- 


12 




Prescale 


— > 


Divider 








J X 


SCK 


A 










12 




/ 




Gated Clock - 


| 




4 


> 




r 

SCKD(1 = 


output) 


WL1 , WLO control reset 

i 1 




Word 
3 Length Divider 




/ 


1 


< 










-\ 














bit clock 






RX shift 
Register 


\ 


RX data 
Register 












> 


















TX shift 
Register 




TX data 
Register 




i — > 



































N 



Figure 8-5 RSSI Clock Generator Functional Block Diagram 

Figure 8-6 shows frame sync generation. When internally generated, both receive and 
transmit frame sync are generated from the word clock and are defined by the frame rate 
divider (DC2-DC0) bit and the word length (WL1-WL0) bits of CRA. 
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Figure 8-6 RSSI Frame Sync Generator Functional Block Diagram 
Serial Transmit Data Pin — STD 



The Serial Transmit Data Pin (STD) is used to transmit data from the Serial Transmit Shift 
Register. STD is an output when data is being transmitted and is three-stated between 
data word transmissions and on the trailing edge of the bit clock after the last bit of a word 
is transmitted. 



8.4.2 



Serial Receive Data Pin — SRD 



The Serial Receive Data Pin (SRD) is used to bring serial data into the Receive Data Shift 
Register. 



8.4.3 



Serial Clock — SCK 



The Serial Clock (SCK) pin can be used as either an input or an output. This clock signal 
is used by both the transmitter and receiver and can be either continuous or gated. During 
gated mode, SCK is valid only during the transmission of data, otherwise it is three-stated. 

8.4.4 Serial Frame Sync — SFS 

The Serial Frame Sync (FS) pin can be used as either an input or an output. The frame 
sync is used by both the transmitter and receiver to synchronize the transfer of data. The 
frame sync signal can be one bit or one word in length and can occur one bit before the 
transfer of data or right at the transfer of data. In the gated clock mode, frame sync sig- 
nals are not used. 
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The pin signals are shown in Figure 8-7. Continuous and gated clock signals are shown 
as well as the bit length and word length frame sync signals. 
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Figure 8-7 Serial Clock and Frame Sync Timing 

8.5 RSSi RESET AND INITIALIZATION PROCEDURE 

The RSSI is affected by three types of reset: 



« 



DSP Reset The DSP hardware reset is generated by asserting the RESET pin or the 
software reset is generated by executing the RESET instruction. The 
DSP hardware or software reset clears the SSI enable bit (SSIEN) in 
control register B which disables the RSSI. All other status and control 
bits in the RSSI are affected as described below. 

RSSI Reset The RSSI reset is generated when the SSI enable bit (SSIEN) in control 
register B is cleared. The RSSI status bits are preset to the same state 
produced by the DSP reset. The RSSI control bits are unaffected. The 
RSSI reset is useful for selective reset of the RSSI interface without 
changing the present RSSI control bits and without affecting the other 
peripherals. 
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STOP Reset The STOP reset is caused by executing the STOP instruction. During 
the stop state no clocks are active in the chip. The RSSI status bits are 
preset to the same state produced by the DSP reset. The RSSI control 
bits are unaffected. 

The correct sequence to initialize the RSSI interface is as follows: 

1 . DSP reset or RSSI reset. 

2. Program RSSI control registers. 

3. Set the SSI enable bit (SSIEN) in control register B. 

The DSP programmer should use the DSP or RSSI reset before changing the MOD, FSI, 
FSL, SHFD, SCKP, SCKD, FSD, GCK, ELFS, WLO, or WL1 control bits to ensure proper 
operation of the RSSI interface. That is, these control bits should not be changed during 
RSSI operation. 

Note: The RSSI clock must go low for at least one complete period to ensure proper RSSI 
reset. 

8.6 RSSI INTERFACE PROGRAMMING MODEL 

The registers comprising the RSSI interface are shown in Figure 8-8. Note that the Codec 
device labels the MSB as bit 0, whereas the DSP labels the LSB as bit 0. Therefore, when 
using a standard Codec, the DSP MSB (or Codec bit 0) is shifted out first, and the MSB 
of CRB should be cleared. 
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■ Reserved bits, read as zero, should be written with zero for future compatibility. 
Figure 8-8 RSSI Programming Model 
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8.7 RSSI TRANSMIT SHIFT REGISTER 

The Transmit Shift Register (TSR) is a 16 bit shift register that contains the data being 
transmitted. When a continuous clock is used, data is shifted out to the serial transmit data 
STD pin by the selected (internal/external) bit clock when the associated (internal/exter- 
nal) frame sync is asserted. When a gated clock is used, data is shifted out to the serial 
transmit data STD pin by the selected (internal/external) gated clock. The Word Length 
control bits (WL1-WL0), in RSSI Control Register A, determine the number of bits to be 
shifted out of the TSR before it is considered empty and may be written to again. This 
word length can be 8, 12, or 16 bits. The data to be transmitted occupies the most signif- 
icant portion of the shift register. The unused portion of the register is ignored. Data is al- 
ways shifted out of this register with the most significant bit (MSB) first when the SHFD bit 
of the control register B is cleared. If this bit is set, the least significant bit (LSB) is shifted 
out first. 

8.8 RSSI TRANSMIT DATA REGISTER (TX) 

The Transmit Data Register is a 1 6-bit write-only register. Data to be transmitted is written 
into this register and is automatically transferred to the transmit shift register. The data 
written should occupy the most significant portion of the transmit data register. The un- 
used bits (least significant portion) of the transmit data register are don't care bits. The 
DSP is interrupted whenever the transmit data register becomes empty provided that the 
transmit data register empty interrupt has been enabled. 

Note: When early frame sync is selected (ELFS=1), if data is written into TX in the time 
between the frame sync and transmission of the first bit, the data will not be trans- 
mitted. TDE and TUE will be set when the first bit is transmitted. 

8.9 RSSI RECEIVE SHIFT REGISTER 

The Receive Shift Register is a 16 bit shift register that receives incoming data from the 
serial receive data SRD pin. When a continuous clock is used, data is shifted in by the 
selected (internal/external) bit clock when the associated (internal/external) frame sync is 
asserted. When a gated clock is used, data is shifted in by the selected (internal/external) 
gated clock. Data is assumed to be received most significant bit (MSB) first if the SHFD 
bit of CRB is cleared. If this bit is set, the data is received least significant bit (LSB) first. 
Data is transferred to the RSSI Receive Data Register after 8, 12, or 16 bits have been 
shifted in depending on the Word Length control bits (WL1 -WLO) in RSSI Control Register 
A. 

8.10 RSSI RECEIVE DATA REGISTER (RX) 

The RSSI Receive Data Register is a 16 bit read-only register that accepts data from the 
Receive Shift Register as it becomes full. The data read will occupy the most significant 
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portion of the receive data register. The unused bits (least significant portion) will read as 
zeros. The DSP is interrupted whenever the receive data register becomes full if the as- 
sociated interrupt is enabled. 

8.11 RSSI CONTROL REGISTER A (CRA) 

The RSSI Control Register A (CRA) is one of two 16 bit read/write control registers used 
to direct the operation of the Synchronous Serial Interface. The CRA controls the RSSI 
clock generator bit and frame sync rates, word length, and number of words per frame for 
the serial data. The DSP reset clears all CRA bits. RSSI reset and STOP reset do not af- 
fect the CRA bits. The CRA control bits are described in the following paragraphs. 
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14 


13 


12 


11 


10 
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PSR 


WL1 


WLO 


* 


* 


DC2 


DC1 


DCO 


7 


6 


5 


4 


3 


2 


1 





PM7 


PM6 


PM5 


PM4 


PM3 


PM2 


PM1 


PMO 



READ-WRITE 
RSSI CONTROL 
REGISTER A (CRA) 
ADDRESS $FFD0/D8 



*unused bits should be set to zero 

8.1 1 .1 CRA Prescale Modulus Select (PM7-PM0) Bits 0-7 

The Prescale Modulus Select bits (PM7 through PMO) specify the divide ratio of the pres- 
cale divider in the RSSI clock generator. This prescaler is used only in internal clock mode 
to divide the internal clock of the core. A divide ratio from 1 to 256 (PM=$00 to $FF) may 
be selected.The bit clock output is available at the clock SCK. The bit clock output is also 
available internally for use as the bit clock to shift the transmit and receive shift registers. 
Careful choice of the crystal oscillator frequency and the prescaler modulus will allow the 
telecommunication industry standard codec master clock frequencies of 2.048 MHz, 
1 .544 MHz, and 1 .536 MHz to be generated. For example, a 24.576 MHz clock frequency 
may be used to generate the standard 2.048 MHz and 1 .536 MHz rates, and a 24.704 
MHz clock frequency may be used to generate the standard 1.544 MHz rate.Table 8-2. 
gives examples of PM7-PM0 values that can be used in order to generate different bit 
clocks. 
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Table 8-2. RSSI bit clock as a function of Fosc and PM7-PM0 (PSR=0) 



Fosc 


Max bit 


PM7-PM0 Values for different SCK 






Clock 












(MHz) 


(MHz) 


2.048Mhz 


1.544Mhz 


1.536Mhz 


128Khz 


64Khz 


16.384 


4.096 


1 








31 ($1 F) 


63($3F) 


18.432 


4.608 


— 


— 


2 


35($23) 


71 ($47) 


20.480 


5.12 


— 


— 


— 


39($27) 


79($4F) 


26.624 


6.656 


— 


— 


— 


51 ($33) 


103($67) 


24.576 


6.144 


2 


— 


3 


47($2F) 


95($5F) 


24.704 


6.176 


— 


3 


— 


— 


— 


32.768 


8.192 


3 


— 


— 


63($3F) 


127($7F) 


36.864 


9.216 


— 


— 


5 


71 ($47) 


143(8F) 


49.152 


12.288 


5 


— 


7 


95($5F) 


191($BF) 


49.408 


12.352 


" 


7 


. 


-~ 





The bit clock on the RSSI can be calculated from the Fosc value using the following equa- 
tion: 

SCK = Fosc (4x[7PSR+1]x(PM+1)) 

8.1 1 .2 CRA Frame Rate Divider Control (DC2-DC0) Bits 8-10 

The Frame Rate Divider Control bits (DC2, DC1 , and DC0) control the divide ratio for the 
programmable frame rate dividers. It operates on the word clock. 

In normal mode, this ratio determines the word transfer rate. In network mode this ratio 
may be interpreted as the number of words per frame. The divide ratio may range from 1 
to 8 (DC = 000 to 1 1 1) for normal mode and 2 to 8 (DC = 001 to 1 1 1) for network mode. 



Examples: 

In 8 bit word normal mode: 

DC2-DC0= 1. PM7-PM0=9. PSR=1. Fosc = 40.96MHz would give a bit clock of 
40.96Mhz -r [8x4x10] = 128 kHz. The 8-bit word rate being equal to two, the 
sampling rate (FS rate) would then be 128 kHz ~ [2x8] = 8kHz. 

In 8 bit word network mode: 

DC2-DC0= 6. PM7-PM0=80. PSR=0. Fosc = 62.22MHz would give a bit clock of 
62.22Mhz -r [4x81] = 0.192 MHz for a 7 slot TDM multiplex of 8-bit words. The 
sampling rate for every word (FS rate) would then be 0.192 MHz -r [3x8] = 8kHz. 
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8.11.3 CRA Word Length Control (WLO, WL1) Bits 13 and 14 

The Word Length Control bits (WL1-WL0) are used to select the length of the data words 
being transferred via the RSSI. Word lengths of 8, 1 2 or 1 6 bits may be selected as shown 
in Table 8-3. 



Table 8-3. RSSI Data Word Lengths 



WL1 


WLO 


Number of bits/word 








8 





1 


(Reserved) 


1 





12 


1 


1 


16 



These bits control the Word Length Divider shown in the RSSI Clock Generator. The WL 
control bits also control the frame sync pulse length when FSL=0. 

8.1 1 .4 CRA Prescaler Range (PSR) Bit 1 5 

The Prescaler Range (PSR) controls a fixed divide-by-eight prescaler in series with the 
variable prescaler. It is used to extend the range of the prescaler for those cases where a 
slower bit clock is desired. When PSR is cleared, the fixed prescaler is bypassed. When 
PSR is set, the fixed divide-by-eight prescaler is operational. This allows a 1 28kHz master 
clock to be generated for Motorola MC1 440X series codecs. The maximum internally gen- 
erated bit clock frequency is Fosc/4 and the minimum internally generated bit clock 
frequency is Fosc/(4*8*256). 

8.12 RSSI CONTROL REGISTER B (CRB) 

The RSSI Control Register B (CRB) is one of two 16 bit read/write control registers used 
to direct the operation of the RSSI. The RSSI reset is controlled by a bit in the CRB. CRB 
controls the direction of the bit clock pin SCK and the frame sync pin FS. Interrupt enable 
bits for each data register interrupt are provided in this control register. RSSI operating 
modes are also selected in this register. The DSP reset clears all CRB bits. However, 
RSSI reset and STOP reset do not affect the CRB bits. The RSSI Control Register B bits 
are described in the following paragraphs. 
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14 


13 


12 


11 


10 


9 


8 


RIE 


TIE 


RE 


TE 


MOD 


SSI EN 


FSI 


FSL 


7 


6 


5 


4 


3 


2 


1 





SHFD 


SCKP 


SCKD 


FSD 


GCK 


ELFS 


* 


* 



READ-WRITE 
RSSI1 CONTROL 
REGISTER B (CRB) 
ADDRESS $FFD1/D9 



*Unused bits should be set to zero. 



8.12.1 CRB Early/Late Frame Sync Bit (ELFS) Bit 2 

The early/late frame sync bit (ELFS) controls when the frame sync is initiated for the trans- 
mit and receive sections. When ELFS is cleared, the frame sync is initiated as the first bit 
of data is transmitted and/or received. When ELFS is set, the frame sync is initiated one 
bit before the data is transmitted and/or received. The frame sync is disabled after one bit 
for bit length frame sync and after one word for word length frame sync. 

8.12.2 CRB Gated Clock (GCK) Bit 3 

The gated clock bit (GCK) selects the type of clock signal used to clock the Transmit Shift 
Register and the Receive Shift Register. When GCK is cleared, the clock signal is a con- 
tinuous clock. When GCK and SCKD are set, the clock signal is an internally gated clock. 
The internally gated clock will run only when the transmitter is enabled (TE=1) during a 
valid time slot. When GCK is set and SCKD is cleared, the clock signal is an externally 
gated clock. The gated clock signal is useful when interfacing with microcontrollers. 

8.12.3 CRB Frame Sync Direction (FSD) Bit 4 

The Frame Sync Direction bit (FSD) controls the direction of the FS pin for the transmit 
and receive sections. When FSD is cleared, the FS pin is an input, meaning that the frame 
sync is supplied from an external source. When FSD is set, the FS pin is an output, 
meaning that the frame sync is generated internally. 

8.12.4 CRB Clock Source Direction (SCKD) Bit 5 

The Clock Source Direction bit (SCKD) selects the source of the clock signal used to clock 
the Transmit Shift Register and the Receive Shift Register. When SCKD is set, the clock 
source is internal and is the bit clock output of the RSSI clock generator. This clock will 
also appear at the SCK pin when SCKD is set. When SCKD is cleared, (1) the clock 
source is external, (2) the internal clock generator is disconnected from the SCK pin and 
(3) an external clock source may drive this pin to clock the Transmit Shift Register and the 
Receive Shift Register. 
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8.12.5 CRB Clock Polarity Bit (SCKP) Bit 6 

The clock polarity bit controls which bit clock edge is used to clock out data and latched 
in data. If SCKP=0, the data is clocked out on the rising edge of the bit clock and latched 
in on the falling edge of the clock. If SCKP = 1 , the falling edge of the clock is used to clock 
the data out and the rising edge of the clock is used to latch the data in. 

8.12.6 CRB MSB/LSB Position Bit (SHFD) Bit 7 

The SHFD bit controls whether the MSB or LSB is transmitted and received first. If SHFD 
= 0, the data is transmitted and received MSB first. If SHFD = 1 , the LSB is transmitted 
and received first. 

8.12.7 CRB Frame Sync Length (FSL) Bit 8 

The Frame Sync Length (FSL) bit selects the length of the frame sync signal to be gener- 
ated or recognized. If FSL=1 , then a one clock bit long frame sync is selected. If FSL=0, 
a one word long frame sync is selected.The length this frame sync is the same as the 
length of the data word selected by WLO and WL1 . 

8.12.8 CRB Frame Sync Invert (FSI) Bit 9 

The Frame Sync Invert (FSI) bit selects the logic of frame sync I/O. If FSI=1, the frame 
sync is active low. If FSL=0, the frame sync is active high. 

8.12.9 CRB RSSI Enable Bit (SSIEN) Bit 10 

The RSSI enable (SSIEN) bit enables and disables the RSSI. If SSIEN=1 , the RSSI is en- 
abled, which causes an output frame sync to be generated (FSD=1) or causes the RSSI 
to wait for the input frame sync (FSD=0). If SSIEN=0, the RSSI is disabled. When dis- 
abled, the output clock and frame sync will be three-stated, the status register bits will be 
preset to the same state produced by the DSP reset, and the control register bits will not 
be affected. 

8.12.10 CRB RSSI Mode Select (MOD) Bit 11 

The Mode select bit (MOD) selects the operational mode of the RSSI. When MOD is 
cleared, the normal mode is selected. When MOD is set, the network mode is selected. 

8.12.11 CRB RSSI Transmit Enable (TE) Bit 12 

The RSSI Transmit Enable (TE) bit enables the transfer of TX to the Transmit Shift 
Register and also enables the internal gated clock. When TE is set and a word boundary 
is detected, the transmit portion of the RSSI is enabled. When TE is cleared, the 
transmitter will continue to transmit the data currently in the RSSI Transmit Shift Register 
and then disable the transmitter. The serial output is three-stated and any data present in 
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TX will not be transmitted, i.e. data can be written to TX with TE cleared, TDE will be 
cleared but data will not be transferred to the Transmit Shift Register. If TE is disabled and 
then re-enabled during the same transmitted word, then the data will continue to be 
transmitted. If TE is re-enabled during a different word slot, then data will not be 
transmitted until the next word boundary.The normal transmit enable sequence for 
transmit is to write data to TX or to TSR before setting TE. The normal transmit 
disable sequence is to clear TE and TIE after TDE=1. 

When an internal gated clock is being used, the gated clock will run during valid word slots 
if the TE bit is set. If TE is disabled, the transmitter will continue to transmit the data 
currently in the RSSI Transmit Shift Register and then the clock will stop. When TE is 
re-enabled, the gated clock will start immediately and will run during any valid word slots. 

Note: The function of disabling and enabling TE is different from the DSP56156 SSI. 

8.12.12 CRB RSSI Receive Enable (RE) Bit 13 

When the RSSI Receive Enable (RE) bit is set, the receive portion of the RSSI is enabled. 
When this bit is cleared, the receiver will be disabled by inhibiting data transfer into RX. If 
data is being received while this bit is cleared, the rest of the word will not be shifted in 
and transferred to the RSSI Receive Data Register. If RE is re-enabled during a word slot 
before the second to last bit then that word will be received. 

Note: The function of disabling and enabling RE is different from the DSP56156 SSI. 

8.12.13 CRB RSSI Transmit Interrupt Enable (TIE) Bit 14 

When the RSSI Transmit Interrupt Enable bit (TIE) is set, the program controller will be 
interrupted when the RSSI Transmit Data Register Empty flag (TDE) in the RSSI Status 
Register is set. When TIE is cleared, this interrupt is disabled. However, the TDE bit will 
always indicate the transmit data register empty condition even when the transmitter is 
disabled by the TE bit. Writing data to the TX or TSR register will clear TDE thus clearing 
the interrupt. 

There are two transmit data interrupts (these have separate interrupt vectors): 

1 . Transmit data with exception status. 

This interrupt is generated on the following condition: 

TIE=1 andTDE=1 andTUE=1 

2. Transmit data without exceptions. 

This interrupt is generated on the following condition: 

TIE=1 and TDE=1 and TUE=0 
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8.12.14 CRB RSSI Receive Interrupt Enable (RIE) Bit 15 

When the RSSI Receive Interrupt Enable bit (RIE) is set, the program controller will be 
interrupted when the RSSI Receive Data Register Full flag (RDF) in the RSSI Status Reg- 
ister is set. If RIE is cleared, this interrupt is disabled. However, the RDF bit still indicates 
the receive data register full condition. Reading the receive data register will clear RDF 
and thus clear the pending interrupt. 

There are two receive data interrupts which have separate interrupt vectors: 

1 . Receive Data with exception status — This interrupt is generated on the following 
condition; 

RIE=1 and RDF=1 and ROE=1 

2. Receive Data without exceptions — This interrupt is generated on the following 
condition: 

RIE=1 and RDF=1 and ROE=0 

8.13 RSSI STATUS REGISTER 

The RSSI Status Register (SR) is a 16-bit read only status register used by the DSP to 
interrogate the status and serial input flags of the Synchronous Serial Interface. The sta- 
tus bits are described in the following paragraphs. 



READ-ONLY 
RSSI STATUS 
REGISTER (SR) 
ADDRESS $FFF0/F8 



H 



RDF 


TDE 


ROE 


TUE 


TRFS 


* 


* 


* 



*Unused bits should be set to zero. 



Note: All the flags in the SR are updated after the first bit of the next SSI word has com- 
pleted transmission or reception. 

8.13.1 RSSISR Transmit/Receive Frame Sync (TRFS) Bit 3 

When set, the Transmit/Receive Frame Sync flag (TRFS) indicates that a frame sync oc- 
curred during transmission of the last word written to the Tx register or receiving of the 
next word into the Rx register. Data written to the transmit data register during the time 
slot when TRFS is set will be transmitted during the second time slot (network mode) or 
in the next first time slot (normal mode). In network mode, TRFS is set during transmission 
or receiving of the first slot of the frame. It will then be cleared when starting transmission 
or receiving of the next slot 
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TRFS is cleared by DSP, RSSI or STOP reset. 

Note: This bit functions differently than the DSP56156 SSI TFS/RFS bits. 

8.13.2 RSSISR Transmitter Under run Error (TUE) Bit 4 

The Transmitter Underrun Error (TUE) flag is set when the Serial Transmit Shift Register 
is empty (no data to be transmitted) and a transmit time slot occurs. When a transmit un- 
derrun error occurs, the previous data will be re-transmitted. 

A transmit time slot in the normal mode occurs when the frame sync is asserted. In the 
network mode, each time slot requires transmit data and is therefore a transmit time slot. 
(TE=1) 

TUE does not cause any interrupts; however, TUE does cause a change in the interrupt 
vector used for transmit interrupts so that a different interrupt handler may be used for a 
transmit underrun condition. If a transmit interrupt occurs with TUE set, the Transmit Data 
With Exception Status interrupt will be generated. If a transmit interrupt occurs with TUE 
clear, the Transmit Data Without Errors interrupt will be generated. 

TUE is cleared by DSP, RSSI, or STOP reset. TUE is cleared by reading the SR with TUE 
set followed by writing TX or TSR. 

8.13.3 RSSISR Receiver Overrun Error (ROE) Bit 5 

The Receiver Overrun Error flag (ROE) is set when the serial receive shift register is filled 
and ready to transfer to the receiver data register (RX) and the RX is already full (i.e. 
RDF=1). The Receiver Shift Register is not transferred to RX. ROE does not cause any 
interrupts; however, ROE does cause a change in the interrupt vector used so that a dif- 
ferent interrupt handler may be used for a receive overrun condition. If a receive interrupt 
occurs with ROE set, the Receive Data With Exception Status interrupt will be generated 
and if a receive interrupt occurs with ROE clear, the Receive Data Without Errors interrupt 
will be generated. 

ROE is cleared by DSP, RSSI, or STOP reset and is cleared by reading the SR with ROE 
set followed by reading the RX. Clearing RE does not affect ROE. 

8.13.4 RSSISR Transmit Data Register Empty (TDE) Bit 6 

The RSSI Transmit Data Register Empty flag (TDE) is set when the contents of the Trans- 
mit Data Register are transferred to the Transmit Shift Register. When set, TDE indicates 
that data should be written to the TX or to the time slot register (TSR) before the transmit 
shift register becomes empty (which would cause an underrun error). 

TDE is cleared when the DSP writes to the Transmit Data Register or when the DSP 
writes to the TSR to disable transmission of the next time slot. If TIE is set, a RSSI Trans- 
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mit Data interrupt request will be issued when TDE is set. The vector of the interrupt will 
depend on the state of the Transmitter Underrun TUE bit. TDE is set by DSP, RSSI, and 
STOP reset. 

8.13.5 RSSISR Receive Data Register Full (RDF) Bit 7 

The RSSI Receive Data Register Full flag (RDF) is set when the contents of the Receive 
Shift Register are transferred to the Receive Data Register. RDF is cleared when the DSP 
reads the Receive Data Register. If RIE is set, a, DSP receive data interrupt request will 
be issued when RDF is set. The interrupt request vector will depend on the state of the 
Receiver Overrun ROE bit. RDF is cleared by DSP, RSSI, and STOP reset. 

8.14 TIME SLOT REGISTER — TSR 

The Time Slot Register (TSR) is used when the data is not to be transmitted in the avail- 
able transmit time slot. For the purposes of timing, the time slot register is a write-only reg- 
ister that behaves like an alternative transmit data register except that rather than trans- 
mitting data, the transmit data pin, STD is three-stated. Using this register is important for 
avoiding overflow/underflow during inactive time slots. 

8.15 NORMAL AND NETWORK OPERATING MODES 

In the normal mode, the frame rate divider determines the word transfer rate — one word 
is transferred per frame sync during the frame sync time slot. In network mode, a word is 
(possibly) transferred every time slot. 

8.15.1 Normal Mode Transmit 

The conditions for data transmission from the RSSI are: 

1. SSI enabled (SSIEN=1) 

2. Transmitter Enabled (TE=1) 

3. Frame sync is active (continuous clock only) 

4. Bit clock begins (gated clock only) 

When the above conditions occur in normal mode, the next data word will be transferred 
from TX to the transmit shift register, the TDE flag will be set (transmitter empty), and the 
transmit interrupt will occur if TIE=1 (transmit interrupt is enabled). The new data word will 
be transmitted immediately. 

The transmit data output (STD) is three-stated except during the data transmission period. 
For a continuous clock, the optional frame sync output and clock outputs are not 
three-stated even if both receiver and transmitter are disabled. 
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8.15.2 



Normal Mode Receive 



If the receiver is enabled, then for a continuous clock, each time the frame sync signal is 
generated (or detected) a data word will be clocked in, and for a gated clock, each time 
the clock begins a data word will be clocked in. After receiving the data word it will be 
transferred from the RSSI Receive Shift Register to the Receive Data Register (RX), the 
RDF flag will be set (Receiver full), and the Receive Interrupt will occur if it is enabled 
(RIE-1). 

The DSP program has to read the data from RX before a new data word is transferred 
from the Receive Shift Register, otherwise the Receiver Overrun error will be set (ROE). 

The transmitter and receiver timing in normal mode for an eight bit word with two words 
per time slot is shown in Figure 8-9. Both continuous and gated clock are shown with a 
late word length frame sync. 
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Figure 8-9 Normal Mode Timing 



8.15.3 



Network Mode 



In this mode, the RSSI can be used in TDM networks. It is the typical mode in which the 
DSP would interface to a TDM codec network or a network of DSPs. The DSP may be a 
master device that controls its own private network or a slave device that is connected to 
an existing TDM network and occupies a few time slots. The distinction of the network 
mode is that it identifies each time slot (data word time) and allows the option of ignoring 
the time slot by writing to TSR or transmitting data during the time slot. The receiver is 
treated in the same manner except that data is always being shifted into the Receive Shift 
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Register and transferred to the RX. The DSP will read the receive data register and either 
use it or discard it. 

The frame sync signal indicates the beginning of a new data frame. Each data frame is 
divided into time slots and transmission and/or reception can occur in each time slot (rath- 
er than in just the frame sync time slot as in normal mode). The frame rate dividers, con- 
trolled by DC2, DC1 , and DCO select two to eight time slots per frame. 

8.15.3.1 Network Mode Transmit 

The transmit portion of RSSI is enabled when SSIEN=1 and TE=1 . However, for continu- 
ous clock, when TE is set, the transmitter will be enabled only after detection of a new 
word slot (if TE is enabled during a slot other than the first). This is different from the 
DSP56156 SSI. Software will have to find the start of the next frame. For a gated 
clock, when TE is set, the transmitter will be enabled as soon as the clock begins. 

Normal start up sequence for transmission is to: 

1 . Write the data to be transmitted to the Transmit Register (TX). This clears the 
TDE flag. 

2. Set TE and TIE to enable the transmitter 

- on the next word boundary (continuous clock) 

- or on the next clock signal (gated clock). 

3. Enable transmit interrupts. 

Alternatively, the DSP programmer may decide to NOT transmit in a time slot by writing 
to the Time Slot Register (TSR). This will clear the TDE flag just as if data were going to 
be transmitted but the STD pin will remain in three-state during the time slot. 

When the frame sync is detected or generated (continuous clock) or the first clock signal 
is detected or generated (gated clock) then the first enabled data word will be transferred 
from TX to the Transmit Shift Register and will be shifted out (transmitted). TX now being 
empty will cause TDE to be set which, if TIE is set, will cause a transmitter interrupt. Soft- 
ware can poll TDE or use interrupts to reload the TX register with new data for the next 
time slot or write to the TSR to prevent transmitting in the next time slot. Failing to reload 
TX (or writing to the TSR) before the Transmit Shift Register is finished shifting (empty) 
will cause (1) a transmitter underrun, (2) the TUE error bit to be set and (3) the STD pin 
will be three-stated for the next time slot. 

The operation of clearing TE will disable the transmitter after completion of transmission 
of the current data word. Setting TE will enable transmission of the next word. During that 
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time the STD pin will be three-stated. TE should be cleared after TDE is set to ensure that 
all pending data is transmitted. 

To summarize, the network mode transmitter generates interrupts every enabled time slot 
and requires the DSP program to respond to each enabled time slot. These responses 
may be: 

1 . Write data register with data to enable transmission in the next time slot. 

2. Write the time slot register to disable transmission in the next time slot. 

3. Do nothing — transmit underrun will occur at the beginning of the next time slot and 
the previous data will be transmitted. 

8.15.3.2 Network Mode Receive 

The receiver portion of the RSSI is enabled when SSIEN=1 and RE =1. However, the re- 
ceive enable will only take place during that word slot if RE is enabled before the second 
to last bit of the word. If the RE bit is cleared, the receiver will be disabled immediately. 
This is different from the DSP561 56 SSI. Software will have to find the start of the next 
frame. 

When the word is completely received, it is transferred to the RX data register which sets 
the RDF flag (Receive Data register full). Setting RDF will cause a receive interrupt to oc- 
cur if the receiver interrupt is enabled (RIE=1). 

The second data word (second time slot in the frame), begins shifting in immediately after 
the transfer of the first data word to the RX data register. The DSP program has to read 
the data from the RX data register (which clears RDF) before the second data word is 
completely received (ready to transfer to RX data register) or a receive overrun error will 
occur (ROE is set). 

An interrupt can occur after the reception of each enabled data word or the programmer 
can poll the RDF flag. The DSP program response can be: 

1 . Read RX and use the data. 

2. Read RX and ignore the data. 

3. Do nothing — the receiver overrun exception will occur at the end of the current 
time slot. 

Note: For a continuous clock, the optional frame sync output and clock output signals are 
not affected even if the transmitter and/or receiver are disabled. TE and RE do not 
disable the bit clock or the frame sync generation. The only way to disable the bit 
clock and the frame sync generation is to disable the SSI enable bit (SSIEN) in con- 
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trol register B. However, for a gated clock, no frame sync signals will be output and 
the clock signal is only enabled when TE is enabled and it is a valid time slot. 

The transmitter and receiver timing for an eight bit word with three words per frame sync 
in network mode is shown in Figure 8-10 and Figure 8-1 1. A gated clock is shown in Fig- 
ure 8-10 with the TE and RE bits. A continuous clock is shown in Figure 8-1 1 with the 
transmit and receive flags. 




Figure 8-10 Network Mode Timing (Gated Clock) 
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Figure 8-11 Network Mode Timing (Continuous Clock) 
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9.1 INTRODUCTION 

The DSP56166 does not contain an on-chip oscillator. An external system clock must be 
provided through the EXTAL input pin. The on-chip phase locked loop (PLL) can be used 
to generate the DSP561 6 core system clock or it can be bypassed allowing the DSP561 6 
core to directly use the clock provided on the EXTAL pin. 

Figure 9-1 shows the general block diagram of the on-chip frequency synthesizer. 

The 4-bit divider ID3-ID0 defines the resolution of the PLL and divides the incoming clock 
rate fed to the PLL. The eight down counter bits YD7-YD0 control down counting in the 
PLL feedback loop causing it to divide by the value YD+1 (any number between 1 and 
256) which effectively multiplies the frequency out of the PLL. The VCO output can be di- 
vided down by any power of 2 between 2° and 2 15 before entering the core using the 4- 
bits PD3-PD0 of the control register PCR1 . The system frequency on the DSP core is con- 
trolled by the frequency control bits of the PLL control register PCRO as follows: 

Fosc = {Fext[ID+1]}x[YD+1] -r (2 PD ) 

where ID is the value contained in ID3-ID0, YD is the value contained in YD7-YD0, and 
PD is the value contained in PD3-PD0. Fext is a squared and delayed version of the clock 
signal applied to the EXTAL input pin. 

Note: The STOP instruction does not power down the PLL if the PLL is enabled 
(PLLD=0) when entering the STOP mode. STOP will power down the ID register if 
the PLL is disabled (PLLD=1) when entering the STOP mode, (see Section 9.3.4). 
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On-chip Frequency Synthesis Control/Status Registers 
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Figure 9-1 . DSP56166 Frequency Synthesizer 
Block Diagram and Control Registers 

9.2 ON-CHIP CLOCK SYNTHESIS CONTROL REGISTER PCRO 

The Clock Synthesis Control Register PCRO is a 16-bit read/write register used to direct 
the operation of the on-chip clock synthesis. The PCRO controls the frequency program- 
ming of the PLL. The PCRO control bits are described in the following sections. 

All PCRO bits of are cleared by DSP hardware. Software reset does not affect this register. 

9.2.1 PCRO Feedback Divider Bits (YD7-YD0) Bits 0-7 

The eight feedback divider bits YD7-YD0 control the down counter in the feedback loop, 
causing it to divide by the value YD+1 where YD is the value contained in the eight bits. 
Changing these bits requires a time delay for the Voltage Controlled Oscillator (VCO) to 
lock again. 
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The LOCK bit is cleared any time a new value is written to the YD bits. 

The resulting DSP core system clock must be within the limits specified by the DSP56166 
Technical Data Sheet (order number DSP56166/D). The frequency of the VCO should 
also remain higher than the minimum value specified in this data sheet. 

9.2.2 PCRO Input Divider Bits (ID3-ID0) Bits 8-1 1 

The four input divider bits are used to divide the input clock frequency by any number be- 
tween 1 and 1 6. The output of the divider is used as input for the phase comparator of the 
PLL. If ID is the value contained in the four bits, the input clock to the PLL is divided by 
ID+1. 

Any time a new value is written to the ID bits, the LOCK bit is cleared. 

9.2.3 PCRO Power Divider Bits (PD3-PD0) Bits 1 2-1 5 

The four power divider bits are used to divide the VCO output clock frequency by any pow- 
er of two between 2° and 2 15 (i.e., 1 , 2, 4, 8, 16, 32, ..., 16384, or 32768). The output of 
the divider can be used as the operating clock for the DSP core, as shown in Figure 9-1 . 
Writing to the PD bits does not affect the LOCK condition of the PLL. 

The PD bits can be used to switch the DSP core back and forth from a high MIPS rate to 
a very low speed, low power mode without having to wait and check for the PLL to lock 
on a new frequency. 

9.3 ON-CHIP CLOCK SYNTHESIS CONTROL REGISTER PCR1 

The Clock Synthesis Control Register PCR1 is a 16-bit read/write register used to direct 
the operation of the on-chip clock synthesizer. The PCR1 control bits are described in the 
following sections. 

All PCR1 bits are cleared by DSP hardware. Software reset does not affect this register. 

9.3.1 PCR1 Reserved Bits — Bits 0-9 

These bits are reserved and should be written as zero by the user. 

9.3.2 PCR1 CLKO Select Bits (CS1-CS0) Bits 10 and 11 

The two CLKO Select bits CS1-CS0 enable one of three possible clocks to be output to 
the CLKO pin when the CD bit in the OMR register is cleared (see Figure 9-1). After hard- 
ware reset, the internal DSP core clock PHO (phase zero) is output to the CLKO pin. PHO 
is a delayed version of the DSP core master clock, Fosc. Changing the value of the two 
bits CS1-CS0 according to Table 9-1, Fext or Fext/2 can be selected to be output on 
CLKO. Fext is a squared and delayed version of the signal applied to the EXTAL input 
pin. 



MOTOROLA DSP561 66 ON-CHIP PLL 9*5 



m 



©NliM^ 



Wm\ 



Table 9-1 CLKOUT Pin Control 



CS1 


cso 


CLKO 








PHO 





1 


Reserved 


1 





Fext 


1 


1 


Fext/2 



9.3.3 PCR1 Phase Select Bit (PS) Bit 12 

This bit is used to select the DSP core clock when the PLL output is not selected 
(PLLE=0). When this bit is cleared, a squared version of EXTAL is selected as Fosc. 
When this bit is set, the output of the ID divider is selected as Fosc. 

9.3.4 PCR1 PLL Power Down Bit (PLLD) Bit 13 

When the PLLD bit is set, the on-chip PLL is powered down. When this control bit is 
cleared, the on-chip PLL is turned on. This bit should not be set when the PLLE bit is set. 

If the PLL has to be turned off before entering the STOP mode, the following sequence 
will have to be executed before the STOP instruction: 

- Clear the PLLE bit (switch back to EXTAL) 

- Set the PLLD bit (power down the PLL) 

- Execute the STOP instruction. 

Setting the PLLD bit clears the LOCK bit. Setting the PLLD bit powers down the complete 
PLL block including the PD and YD registers. 

9.3.5 PCR1 PLL Enable Bit (PLLE) Bit 14 

When the PLLE bit is set, the DSP5616 core system clock is generated by the on-chip 
PLL. Table 9-2 summarizes the function of the three bits — PLLE, PLLD and PS. The 
state of the PLL is defined by the PLLD bit. When the PLLD bit is set, the PLL is in the 
power down mode. When the PLLD bit is cleared, the PLL is in the active mode. Before 
turning the PLL off, the PLLE bit should be cleared in order to by-pass the PLL. The PLL 
can then be put in power down mode by setting PLLD. 

If the output frequency of the PLL has to be changed by re-programming the YD bits while 
the PLL output is used by the core (PLLE=1 ; PLLD=0), the following sequence of opera- 
tions should be performed: 

- Clear the PLLE bit to switch back to EXTAL 
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Program the YD bits (only after clearing PLLE) 

Wait for the LOCK bit to be set 

Set PLLE after the LOCK bit is tested high. 



Table 9-2 PLL Operations 



PLLE 


PLLD 


PS 


Fosc 


PLL Mode 











Fext 


Active 





1 





Fext 


Power Down 








1 


Fext[ID+1] 


Active 





1 


1 


Fext[ID+1] 


Power Down 


1 





X 


{Fext[ID+1]}x[YD+1](2 PD ) 


Active 


1 


1 


X 


Reserved 


— 



9.3.6 PCR1 Voltage Controlled Oscillator Lock Bit (LOCK) Bit 15 

This status bit shows whether the Voltage Controlled Oscillator (VCO) has locked on the 
desired frequency or not. When the LOCK bit is set, the VCO has locked; when the LOCK 
bit is cleared, the VCO has not locked yet. This bit is cleared when setting the PLLD bit 
and when changing the value of ID or YD bits. The LOCK bit is not cleared when clearing 
the PLLE bit without changing the values of PLLD, YD, or ID. 

This bit is read-only and cannot be written by the DSP core. 
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LOCK 



PLL unlocked 
PLL locked 



PLLE PLLD 



00 
01 
10 
11 



PLL active but not used as Fosc 
PLL powered down 
PLL active and used as Fosc 
Reserved 



PHASE 
SELECT 



Squared EXTAL selected as Fosc if PLLE=0 
Squared EXTAL/ID selected as Fosc if PLLE=0 



CS1-CS0 
CLKO 
Select 



00 



PHO output to CLKO when enabled by the CD bit (bit 7) of the OMR 



01 
10 
11 



reserved 



Fext output to CLKO when enabled by the CD bit (bit 7) of the OMR 



Fext/2 output to CLKO when enabled by the CD bit (bit 7) of the OMR 
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Divide the input clock by 1 4 
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Figure 9-2 On-Chip Frequency Synthesizer Programming Model Summary. 
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A.1 INTRODUCTION 

The bootstrap feature of the DSP56166 consists of four special on-chip modules: the 
2048 words of PRAM, a 64-word bootstrap ROM, the bootstrap control logic, and the boot- 
strap firmware program. 

Note: The bootstrap feature is only available on the DSP56166 RAM based part. The 
ROM Based DSP561 66 does not have the bootstrap feature available. As a result, 
this appendix only applies to DSP56166 RAM based part. 
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BOOTSTRAP ROM 



This 64-word on-chip ROM has been factory programmed to perform the actual bootstrap 
operation from the memory expansion port (Port A), the Host Interface, or the RSSIO. 
There is no access to the bootstrap ROM other than through the bootstrap process. Con- 
trol logic will disable the bootstrap ROM during normal operations. 

A.2.1 Bootstrap Control Logic 

The bootstrap mode control logic is activated when the DSP561 66 is placed in Operating 
Mode or 1. The control logic maps the bootstrap ROM into program memory space as 
long as the DSP561 66 remains in Operating Mode or Mode 1 . If the DSP is in Operating 
Mode it will load 4096 bytes from a byte-wide memory (usually an EPROM) beginning 
at location P:$C000. If the DSP is in Operating Mode 1 it will load from either the Host 
Interface or RSSIO depending on whether P:$C000 bit 15 is zero or one, respectively. The 
bootstrap firmware changes operating modes when the bootstrap load is completed. 
When the DSP56166 exits the reset state in Mode or 1 , the following actions occur: 

1. The control logic maps the bootstrap ROM into the internal DSP program memory 
space starting at location $0000. This P: space is read-only. 

2. The control logic forces the entire P: space, including the internal program RAM, to 
be write-only memory during the bootstrap loading process. Attempts to read from 
this space will result in fetches from the read-only bootstrap ROM. 

3. Program execution begins at location $0000 in the bootstrap ROM. The bootstrap 
ROM program is able to perform the PRAM load through either the memory expan- 
sion port from a byte-wide external memory, through the Host Interface, or through 
RSSIO. 

4. The bootstrap ROM program executes the following sequence to end the bootstrap 
operation and begin your program execution. 

A. Enter Operating Mode 2 by writing to the OMR. This action will be timed to re- 
move the bootstrap ROM from the program memory map and re-enable read/ 
write access to the PRAM. 

B. The change to Mode 2 is timed exactly to allow the boot program to execute a 
single cycle instruction then a JMP #00 and begin execution of the program at 
location $0000. 
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The bootstrap mode may also be selected by writing Operating Mode or 1 into the OMR. 
This initiates a timed operation to map the bootstrap ROM into the program address space 
after a delay to allow execution of a single cycle instruction and then a JMP #<00 to begin 
the bootstrap process as described above in steps 1-4. This technique allows the 
DSP56166 user to reboot the system (with a different program if desired). 

A.2.2 Bootstrap Firmware Program 

Bootstrap ROM contains the bootstrap firmware program that performs initial loading of 
the DSP56166 PRAM. The program is written in DSP5616 core assembly language. It 
contains three separate methods of initializing the PRAM: loading from a byte-wide mem- 
ory starting at location P:$C000, loading through the Host Interface, or loading serially 
through RSSIO. The particular method used is selected by whether (1) Operating Mode 
or 1 is chosen and (2) the level of program memory location $C000, bit 15. 

If the DSP is in Operating Mode it will load 4096 bytes from a byte-wide memory (usually 
an EPROM) located in the lower byte beginning at location P:$C000 (see Figure B-1 of 
the applications examples given in APPENDIX B APPLICATIONS EXAMPLES). The 
data contents of the EPROM must be organized as shown below. 

Address of External Contents Loaded 

Byte Wide P Memory to Internal PRAM at: 

P:$C000 P:$0000 low byte 

P:$C001 P:$0000 high byte 



P:$CFFE P:$07FF low byte 

P:$CFFF P:$07FF high byte 

If the DSP is in Operating Mode 1 and bit 1 5 at location P:$C000 is low then the DSP will 
load from the Host Interface. Typically a host microprocessor will be connected to the 
DSP56166 Host Interface (see Figure B-3 of the applications examples given in APPEN- 
DIX B — APPLICATIONS EXAMPLES). The host microprocessor must write the Host In- 
terface registers TXH and then TXL with the desired contents of PRAM from location 
P:$0000 up to P:$0FFF. If less than 2048 words are to be loaded, the host programmer 
can exit the bootstrap program and force the DSP56166 to begin executing at location 
P:$0000 by setting HF0=1 in the Host Interface during the bootstrap load. In most sys- 
tems, the DSP56166 responds so fast that handshaking between the DSP56166 and the 
host is not necessary. 

If the DSP is in Operating Mode 1 and bit 15 at location P:$C000 is high, then the DSP 
will load from RSSIO starting with the least significant byte first. 

The bootstrap program listing is shown in Figure A-1 . 
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; Bootstrap source code for the Motorola 16-bit DSP 
; (C) Copyright 1989 Motorola inc. 

j 

; Host Bootstrap, RSSIO Bootstrap and External Bus Bootstrap 

; This is the Bootstrap program contained in the DSP56166 RAM Based. This program 

; can load the internal program memory from one of 3 external sources. 

; The program reads the OMR bits MA and MB to decide which external source to access. 

; If MB:MA = 00 - load from 4,096 consecutive byte-wide P: memory locations (starting at P:$C000). 

; If MB:MA = 01 - load internal PRAM through the Host Interface if bit 15 of P:$C000 is zero 

; and load internal PRAM through RSSIO if bit 15 of P:$C000 is set. 

; On-chip program RAM size 
; The location in P: memory 
; where the external byte-wide 
; EPROM is to be mapped 
; Port B Control Register 
; Port C Control Register 
; Host Status Register 
; Host Receive Data Register 
; RSSIO Control register A 
; RSSIO Control register B 
; RSSIO Status register 
; RSSIO Serial receive register 

; Bootstrap code starts at P:$0 

; R2= Port B Control Register 
; R1= External P: address of 
; bootstrap byte-wide ROM 

; R3= Port C control Register 



PRAMSIZE 


EQU 


2048 


BOOT 




EQU 


$C000 


M PBC 




EQU 


$FFC0 


M PCC 




EQU 


$FFC1 


M HSR 




EQU 


$FFE4 


M HRX 




EQU 


$FFE5 


M CRAO 




EQU 


$FFD0 


M CRBO 




EQU 


$FFD1 


M SRO 




EQU 


$FFF0 


M RXO 




EQU 


$FFF1 




ORG 


PL:$0 






MOVE 


#M PBC,R2 




MOVE 


#BOOT,R1 





LEA 



(R2)+,R3 



; If this program is entered by changing the OMR to bootstrap mode, make certain that 
; registers M0 and M1 have been set to $FFFF (linear addressing). 
; Make sure the BCR register is set to $xxxF since EPROMs are slow. 

; The first routine will load 4,096 bytes from the external P memory space beginning at 
; P:$C000 (bits 7-0). These will be condensed into 2,048 16-bit words and stored in 
; contiguous internal PRAM memory locations starting at p:$0. 
; Note that the first routine loads data starting with the least significant byte of P:$0 first. 

; The second routine loads the internal PRAM using the HOST interface logic 

; or the RSSIO interface logic 

; It will load 4,096 bytes from the parallel host processor interface if bit 1 5 of P:$COO0 is cleared 

; and from the Serial Synchronous Interface RSSIO if bit 1 5 of P:$C000 is set. 

; These will be condensed into 2,048 16-bit words and stored in contiguous internal PRAM memory 

; locations starting at P:$0. Note that when using the RSSIO, the routine loads data starting with the 

; least significant byte of P:$0 first. 

; If the host processor only wants to load a portion of the p memory, and then start execution of 

; the loaded program, the host interface bootstrap load program routine may be killed by setting 

;HF0 = 1. 
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Figure A-1. DSP561 66 Bootstrap Program Listing 
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MOVE 


P:(R1),A 


Get P:$C000 (clears AO) 




MOVE 


A0,R0 


R0=(0) Starting P: address of 
internal memory where program 
will begin loading 




ROL 


A 


Shift bit 1 5 into the carry flag 




BCC 


<INLOOP 


Perform load from memory or 
host interface if carry is zero. 




ORI 


#$40,CCR 


Set L bit if not (0) 




MOVE 


R0,X:M CRAO 


Set CRAO of RSSIO to 8 bit mode 




MOVE 


#$2400 5 A 






MOVE 


A,X:M_CRB0 


Set CRBO to external clock, sync. mode, 
Late FS mode with reception enabled 




BFSET 


#$E,X:(R3) 


Set PC1,PC2,PC3 to SRD0,SCK0 3 RFS0 


INLOOP 


MOVE 


#PRAMSIZE 3 B1 


Load PRAM size into B1 




DO 


B1 3 _LOOP1 


Load PRAMSIZE instruction words. 




BFTSTH 


#1 5 OMR 


Perform load from Host 




BCC 


<_MEMLD 


Load from memory if MA=0, 


; This is 


the second routine. It loads from the Host interface pins or from the RSSIO pins. 




BLC 


<_HOSTLD 


Load from Host Interface 

if the limit flag is clear 


; Bootstrap byte per byte from RSSIO 




' RSSILD DO #2 3 LOOP2 




_RSSIWTBFTSTL 


#$80 5 X:M SRO 


Test RDF flag 




BCS 


RSSIWT 


Wait for RDF to go high 




MOVEP 


X:M RX0,B 


Put receive RSSIO data in B 




ASR4 


B 






ASR4 


B 






BRA 


< PACK 


where the received byte 


; This is 


the first routine. Its loads from external P 


: memory 


JvlEMLD DO 


#2, LOOP2 


Each instruction has 2 bytes. 




MOVE 


P:(R1)+ 3 B 


Get 8-bit from external P: 


_PACK 


MOVE 


B1 3 A2 


Move the 8-bit into A2 




ASR4 


A 


Shift 4 bit data into A1 




ASR4 


A 


Shift 4 bit data into A1 


J.OOP2 










BRA 


<_STORE 


, Then put the word in P: memory 



Figure A-1. Listing of the DSP56166 Bootstrap Program (Continued) 



A - 6 DSP56J66 RAM BOOTSTRAP MOD1S 



iviofORdMi 



BOOTSTRAP ROM 



; Bootstrap from the parallel host interface 




' HOSTLD 


BFSET 


#1,X:(R2) 


Configure Port B as Host Interface. 


LBLA 


BFTSTH 


#8,X:«M HSR 


Test HFO. 




BRKCS 




Stop loading if HF0=1 . 


' 


BFTSTL 


#1,X:M HSR 


Test HRDF flag 




BCS 


__LBLA 


Wait for HRDF to go high 
(meaning the data is present) 




MOVEP 


X:M HRX,A 


Put 16-bit host data in XO 


„STORE 


MOVE 


A,P:(R0)+ 


Store 1 6-bit result in PRAM 


J_OOP1 








' 


ANDI 


#$FE,OMR 


Clear OMR bit 




ORI 


#$2,OMR 


Set the operating mode to 2 
(and trigger an exit from 
bootstrap mode). 




AND 


#$0,CCR 


Clear SR as if HW reset and 
introduce delay needed for 
operating mode change. 




BRA 


<$0 


Start fetching from PRAM. 




END 







Figure A-1. Listing of the DSP561 66 Bootstrap Program (Continued) 
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DSP561 m RAM BOOTSTRAP MODES 



A-7 



BOOTSTRAP ROM 



WW: 



DSP56166 RAM BOOTSTRAP MODES 



MOTOROLA 



SECTION B 



DSP56166 APPLICATION EXAMPLES 




MOTOROLA DSP56i66 APPLlCAtidN EXAIWPUES B - 1 



The lowest cost DSP561 66-based system is shown in Figure B-1 . It uses no run time ex- 
ternal memory and requires only two chips, the DSP56166 and a low cost EPROM. 

Figure B-2 shows the DSP56166 bootstrapping via the Host Interface from an MC68000. 



Note: Wh en in R ESET. 
IRQAandlRQBmust 
be deasserted by external 
peripherals. 

FROM OPEN v 
COLLECTOR V 

□ i irccn * 



^15K^15K^1 



FROM v 

RESET V 

FUNCTION 



FROM OPEN 
COLLECTOR V 

□ I ICCCD * 



DSP56166 

BR 

) A/IRQ A 

HACK 

RD 

A0-A10 

SET 

D0-D7 



MODC 
TA 



^15K ^15K 



«~^ 



2732 

-<JoE 

A0-A10 
D0-D7 CS 



h. 



Figure B-1 No Glue Logic, Low Cost Memory Port Bootstrap — Mode 



^15K^ 



FROM OPEN v 
COLLECTOR ^- 



FROM . 

RESET > 

FUNCTION 



FROM OPEN 
COLLECTOR V 



^1 5K« 5K^1 5K^ 15K 
L RR 



*t 



BUFFER 



I 



15K^ 



DSP56166 

HEN 



BR 

HACK 

MODA/IRQA 



RESET 



MODB/IRQB 

MODC 

D15 



H0-H7 
HA0-HA2 




" — d LS09} 



4*- 



LDS 
AS 



MC68000 

(12.5MHz) 



D0-D7 
A1-A3 



Figure B-2 DSP56166 Host Bootstrap Example — Mode 1 
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Systems with external program memory can load the on-chip PRAM without using the 
bootstrap mode. In Figure B-3, the DSP56166 is operated in mode 2 with the reset vector 
pointed at external program memory location P:$E000. The programmer can overlay the 
high speed on-chip PRAM with DSP algorithms by using the MOVEM instruction. 



^15K^15K^1 



FROM OPEN x 
COLLECTOR ^~ 



FROM . 

RESET V 

FUNCTION 



FROM OPEN 
COLLECTOR V 
di i pern ' 



2 



1 I 



DSP56166 



RESET HACK 



MODB/IRQB BR 

MODC D °- D15 



A0-A14 CS OE 



2756-30 (2) 

D0-D15 



-*T 



Figure B-3 32K Words of External Program ROM — Mode 2 
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Figure B-4 is a simple manual reset circuit and Figure B-5 adds the ability to remotely re- 
set the DSP. 



Note: IRQA and IRQB must 
be hardwired. 



-o RESET 



: 10 |il 
Note: MODA and MODB must be hard wired. 



Figure B-4 Reset Circuit 



MASTER j A 
RESET ^o 



:i|if 



LOGIC 
RESET 



555 TIMER 

RESET THRESHOLD 

TRIGGER 

OUTPUT 



DISCHARGE 
CONTROL 



:1 MA 






0.47 |if 



Figure B-5 Reset Circuit Using 555 Timer 



-o RESET 



-oOnCE Connector 
ResetJN 
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SECTION C 



DSP56166 PROGRAMMING SHEETS 



The following pages are a set of programming sheets intended to be copied and used to simplify programming the 
various programmable registers in the DSP56166. They are grouped for the core processor and each peripheral. 
Each register includes the name, address, reset value, and meaning of each bit. There is room to write in the value 
for each bit and then the hexadecimal equivalent for each register. 
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DSP56166 On-chip Peripheral Memory Map 

















PERIPHERAL ADDRES 


SES| 






:^y':<:'ym<;:mm:':-^ 




$FFDF 
$FFDE 
$FFDD 
$FFDC 

N $FFDB 
$FFDA 
$FFD9 
$FFD8 
$FFD7 
$FFD6 
$FFD5 
$FFD4 
$FFD3 
$FFD2 
$FFD1 
$FFD0 
$FFCF 
$FFCE 
$FFCD 
$FFCC 
$FFCB 
$FFCA 
; M$FFC9 
$FFC8 
$FFC7 
$FFC6 
$FFC5 
$FFC4 

S j i:iti$FFC3 
$FFC2 
$FFC1 
$FFC0 

erals Memoi 






$FFFF 
$FFFE 
$FFFD 
$FFFC 
$FFFB 
$FFFA 
$FFF9 
$FFF8 
$FFF7 
;$FFF6 
$FFF5 
$FFF4 
$FFF3 
$FFF2 
$FFF1 
$FFF0 
lllilIlli$FFEF 
$FFEE 
$FFED 
$FFEC 
$FFEB 
$FFEA 
SFFE9 
SFFE8 
$FFE7 
$FFE6 
$FFE5 

y i:i$FFE4 

$FFE3 

$FFE2 

;$FFE1 

: :$FFE0 


Reserved for on-chip emulation 


IPR: Interrupt Priority Register 






BCR: Bus Control Register 




IPR2: Interrupt Priority Register 2 




PCR1 




PCRO 




BCR2: Bus Control Register 2 


TX/RX RSSI1 TX/RX Registers 


CRB-RSSI1 Control Register B 


SR/TSR RSSI1 Status Register 


CRA-RSSI1 Control Register A 


























TX/RX RSSIO TX/RX Registers 


CRB-RSSIO Control Register B 


SR/TSR RSSIO Status Register 


CRA-RSSIO Control Register A 


Timer Preload Register (TPR) 




Timer Compare Register (TCPR) 




Timer Count Register (TCTR) 




Timer Control Register (TCR) 












CRX/CTX 


Reserved 


CQSR 


CCR1 




CCRO 






HTX/HRX: Host TX/RX Register 




HSR: Host Status Register 


HCR: Host Control Register 


Port C Data Register (PCD) 


Port C Data Direction Register 


Port B Data Register (PBD) 


Port B Data Direction Register 




Port C Control Register (PCC) 




Port B Control Register (PBC) 






On-chip Periph 


7 Map 
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DSP56166 Interrupts Starting 



Sources 













INTERRUPT VECTOR ADDRESSES 
















interrupt 

Starting 

Address IPL Interrupt Source 




$0000 3 Hardware RESET 

$0002 3 Illegal Instruction 

$0004 3 Stack Error 

$0006 3 Reserved 

$0008 3 SWI 

$000A 0-2 IRQA 

$000C 0-2 IRQB 

$000E 0-2 IRQC 

$001 0-2 RSSIO Receive Data with Exception Status 

$0012 0-2 RSSIO Receive Data 

$001 4 0-2 RSSIOTransmit Data with Exception Status 

$0016 0-2 RSSIO Transmit Data 

$0018 0-2 RSSI1 Receive Data with Exception Status 

$001 A 0-2 RSSI1 Receive Data 

$001 C 0-2 RSSI1 Transmit Data with Exception Status 

$001 E 0-2 RSSI1 Transmit Data 

$0020 0-2 Timer Overflow 

$0022 0-2 Timer Compare 

$0024 0-2 Host DMA Receive Data 

$0026 0-2 Host DMA Transmit Data 

$0028 0-2 Host Receive Data 

$002A 0-2 Host Transmit Data 

$002C 0-2 Host Command (default) 

$002E 0-2 Codec Receive/Transmit 

$0030 0-2 Available for Host Command 

$0032 0-2 Available for Host Command 

$0034 0-2 Available for Host Command 

$007E 0-2 Available for Host Command 






Interrupts Starting Addresses and Sources 
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INSTRUCTIONS 




Mnemonic Syntax Parallel Moves Instruction Osc. 

Program Clock 
Words Cycles 

D (parallel move) 1 2+mv 

S,D (no parallel move) 1 2 

S,D (parallel move) 1 2+mv 

S,D (parallel move) 1 2+mv 

#xx,D 1 2 

D (parallel move) 1 2+mv 

D (no parallel move) 1 2 

D (parallel move) 1 2+mv 

D (no parallel move) 1 2 

D (no parallel move) 1 2 

#iiii,X:<aa> 2 4+mvb 

#iiii,X:<pp> 
#iiii,X:<ea> 
#iiii,D 

#iiii,X:<aa> 2 4+mvb 

#iiii,X:<pp> 
#iiii,X:<ea> 
#iiii,D 

#jiii,X:<aa> 2 4+mvb 

#iiii,X:<pp> 
#iiii,X:<ea> 
#iiii,D 

#iiii,X:<aa> 2 4+mvb 

#iiii,X:<pp> 
#liii,X:<ea> 
#iiii,D 

#iiii,X:<aa> 2 4+mvb 

#iiii,X:<pp> 
#iiii,X:<ea> 
#iiii,D 

xxxx 1 +ea 4+jx 

ee 
Rn 

xxxx 1 +ea 4+jx 

aa 
Rn 

1 2/8 

xxxx 1 +ea 4+jx 

Rn 

xxxx 1 +ea 4+jx 

Rn 

(no parallel move) 1 2 

D (parallel move) 1 2+mv 

D (parallel move) 1 2+mv 

S,D (parallel move) 1 2+mv 

S,D (parallel move) 1 2+mv 

1 4 

1 4 

D (parallel move) 1 2+mv 

D (parallel move) 1 2+mv 

S,D (parallel move) 1 2 

,uu)S1 ,S2,D (no parallel move) 1 2 



ABS 

ADC 

ADD 

AND 

AND(I) 

ASL 

ASL4 

ASR 

ASR4 

ASR16 

BFCHG 



BFCLR 

BFSET 

BFTSTH 

BFTSTL 

Bcc 
BRA 



BRKcc 
BScc 

BSR 

CHKAAU 

CLR 

CLR24 

CMP 

CMPM 

DEBUG 

DEBUGcc 

DEC 

DEC24 

DIV 

DMAC(ss,su 



** ***** 

*- - ??0- 
?? ????? 

r * * * * * /p*p 

f}+ * * * 99 

** * * * Q9 
** * * *Q/p 

***** /\n 
* 7 



- .7 



???- 

* * * * * * r\_ 

_** ****_ 

*** ***** 

*** ***** 



r * * ***** 
• * * * * O* * 

*----' 77 



o 
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DSP56166 Instruction Set Summary 



INSTRUCTIONS 



Mnemonic Syntax 



Parallel Moves 



Instruction Osc. 
Program Clock 
Words Cycles 



SLEUNZVC 



DO X:(Rn) 5 expr 

#xx,expr 
S,expr 

DOFOREVER 

ENDDO 



expr. 



EOR 

EXT 

ILLEGAL 

IMAC 

IMPY 

INC 

INC24 

Jcc 



S,D 
D 



81,82,0 

S1,S2,D 

D 

D 

xxxx 

(Rn) 

xxxx 

(Rn) 

xxxx 

Rn 

xxxx 

D 

D 

(±)S2,S1,D 

S1,S2,D 

S1,S2,D 

(±)S2,S1,D 

S1.S2.D 
MAC(uu,su) S1,S2,D 
MOVE 



(parallel move) . . . 
(no parallel move) . 
(no parallel move) . 
(no parallel move) . 
(no parallel move) . 
(parallel move) . . . 
(parallel move) . . . 



. . 2 
. . 1 
.. 1 
.. 1 
.. 1 
.. 1 
.. 1 
. . 1 
.. 1 
. 1+ea 



6/1 0+mv 



6 

2 
2+mv 

2 

8 

2 

2 
2+mv 
2+mv 
4+jx 



JMP 

JScc 

JSR 
LSL 
LSR 

MAC 



MACR 



. 1 +ea 4+jx 



.1+ea 



.1+ea 
.. 1 
.. 1 
.. 1 



#xxxx,D 

No parallel data move 
Register to register 
data move 

Address register update 
X memory data move 

X memory data move 
with short displacement 
X memory data write 
and register data 
move (MPY or MAC) 
Dual X memory data read 
MOVE(C) X:<ea>,D 
S,X:<ea> 
#xxxx,D 
S,D 

X:(R2+xx),D 
S,X:(R2+xx) 
#xx,D 



(parallel move) . . . 

(parallel move) . . . 

(one parallel move) 
_ (two paralleJLreads) 
D,X:(Rn)+NnS,D 

(one parallel operation). . 1 

(two parallel reads) 

(no parallel move) 1 

(one parallel operation). 1+ea 

(double memory read) 

(memory access, register move) 



..D( );• 



.mv 
.mv 



,)ea mv 

.)X:<ea>,D mv 

.)S,X:<ea> mv 

.)X:(R2+xx),D mv 

.)S,X:(R2+xx) mv 

),X:(Rn)+NnS,D mv 



( )X:<ea>,D1 X:<ea>,D2.mv 

1 +ea 



4+jx 

4+jx 
2+mv 
2+mv 
2+mv 



2+mv 

2 
2+mv 



mv 
mv 

mv 
mv 
mv 
mv 
mv 
mv 



mv 
2+mvc 



MOVE(I) 



*- - ??0- 



*? ?* ??- 

*??* ??- 

: * * ***** 
: * * * * O * * 



* *- - ??0? 

* * -- ??0? 

* * * * * * * 



* * * * * * * 

* * 

* ? 

* ? 

* ? 

* ? 

* ?? ????? 
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Instruction Set i 



I INSTRUCTIONS 



Mnemonic Syntax 



Parallel Moves 



Instruction Osc. 
Program Clock 
Words Cycles 



SLEUNZVC 



MOVE(M) 



MOVE(P) 

MOVE(S) 
MPY 

MPYR 

MPY(su,uu) 

NEG 

NEGC 

NOP 

NORM 

NOT 

OR 

ORI 

REP 



REPcc 

RESET 

RND 

ROL 

ROR 

RTI 

RTS 

SBC 

STOP 

SUB 

SUBL 
SWAP 
SWI 
Tec 

TFR 

TFR(2) 
TFR(3) 

TST 
TST(2) 
WAIT 
ZERO 



P:<ea>,D 

S,P:<ea> 

P:(R2+xx),D 

S,P:(R2+xx) 

P:<ea>,X:<ea> 

X:<ea>,P:<ea> 

X:<pp>,D 

X:<pp>,D 

S,X:<pp> 

X:<pp>,X:<ea> 

X:<aa>,D 

S,X:<aa> 

(±)S1,S2,D 

S1,S2,D 

S1 ,S2,D 

(±)S1,S2,D 

S1,S2,D 

S1,S2,D 

D 

D 



.1+ea 2+mvm 



(one parallel move). 

_ (two parallelxeads) 

D,X:(Rn)+Nn S,D 
one parallel move), 
two parallel reads) 
no parallel move) . . 
parallel move) 
parallel move) 



Rn,D 

D 

S,D 

#xx,D 

X:(Rn) 

#xx 

S 



D 
D 
D 



S,D 

S,D 
S,D 
S,D 
D 

ib D) 

S,D 

S,D 

S.D 

S1.D1 

S1.D1 

S 

S 



(parallel move) . 
(parallel move) . 



(parallel move) 
(parallel move) 
(parallel move) 



(parallel move) 



(parallel move) 
(two parallel reads) 
(parallel move) 
(no parallel move) . . 



R0,Rn 

(one parallel operation). 

(two memory reads) 

(no parallel operation). . 

X:<ea>,D2 

S2, X:<ea> 

(parallel move) 

(no parallel move) 



(no parallel move) . 



4+mvp 

4+mvp 
2+mv 

2+mv 



2+mv 

2 

2 

2 
2+mv 
2+mv 

2 
4/6+mv 



4/6 

4 
2+mv 
2+mv 
2+mv 
4+rx 
4+rx 
2+mv 

n/a 
2+mv 

2+mv 
2 
8 
2 

2+mv 

2 
2+mv 

2+mv 
2 

n/a 
2 



*** ***** 
_** ***** 

* * * * * o 

* *. _ ??o- 

* *_ . ??o- 
. ?? ????? 



* * * * * * * 

* * - - ??0? 

* * - - ??0? 
- ?? ????? 

*** ***** 
*** ***** 

* * * * * * Q* 



** ***qo 

_** *** 00 



m 
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INSTRUCTIONS 



FUNCTIONAL INSTRUCTION SET SUMMARY 





DUAL READ INSTRUCTIONS 






DSP56166 


DATA ALU 
OPERATION 


DOUBLE 

EFFECTIVE 

ADDRESS 


DOUBLE 
DESTINATION 


Operation 


Registers 


Reach 


Read2 


Destl 


Dest2 


MOVE 




(Rn)+ 


(R3)+ 


~F 


XO 


MAC/R 
MPY/R 


X1.Y1.F 
X1.Y0, F 
X0,Y1,F 
XO, YO, F 


(Rn)+Nn 


(R3)+ 


YO 


XO 


(Rn)+ 


(R3)+N3 


X1 


XO 


(Rn)+Nn 


(R3)+N3 


Y1 


XO 


n=[0,2] 

F = 0->A 
F=1 ->B 


XO 


X1 


ADD 
SUB 
TFR 


X1,F 
XO, F 
Y1,F 
YO, F 


YO 


X1 


~F 


YO 


Y1 


X1 


ADD 


-F, F 




SUB 


~F,F 


TFR 


~F, F 
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INSTRUCTIONS 


LIWIS INSTRUCTION 








DSP56166 






DATA ALU 
OPERATION 


DOUBLE 
TRANSFER 


Operation 


Registers 


TRANSFER 


TRANSFER2 


MAC 
MPY 


XO, XO, F 


~F 


(Rn)+Nn 


X1 


~F 


X1,X0, F 


n=[0,2] 

F = 0->A 

F = 1 ->B 

~F= opposite accumulator 


XO 


~F 


A1.Y0, F 


Y1 


~F 


B1,X0, F 


YO 


~F 


YO, X1,F 




Y1,X1,F 


Y1,X0, F 


YO, XO, F 




DATA ALU INSTRUCTIONS WITH ONE PARALLEL OPERATION 






DSP56166 




DATA ALU 
OPERATION 


PARALLEL MEMORY 
READ or WRITE 


Operation 


Registers 


Effective 
Address 


Dest/Source 


MAC 
MPY 


XO, XO, F 
X1,X0, F 
A1,Y0 5 F 
B1,X0, F 
YO, X1,F 
Y1,X1,F 
Y1,X0, F 
YO, XO, F 


(Rn)+ 
(Rn)+Nn 
(~F1) 
(R2+xx) 


X1 

XO 

Y1 

YO 

AO 

BO 

A 

B 


ONE ADDRESS UPDATE 


ADD 

SUB 

TFR 

OR/AND 

EOR 

CMP/CMPM 


X1, F 
XO, F 
Y1,F 
YO, F 


Effective Address 


(Rn)- 


(Rn)+Nn 


PARALLEL REGISTER 
TRANSFER 


Source 


Destination 
















XO 


~F 



M 
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DATA ALU INSTRUCTIONS WITH ONE PARALLEL OPERATION 




DSP56166 




DATA ALU 
OPERATION 


PARALLEL MEMORY 
READ or WRITE 




ADD 
SUB 


X, F 
Y, F 


X1 


-F 




YO 


~F 




MOVE 




Y1 


~F 




SBC 


X 5 F 
Y, F 


A 


XO 




A 


X1 




CMP/CMPM 
SUBL, TFR 
ADD, SUB 


~F, F 


B 


YO 




B 


Y1 




RND 

TST 

ABS 

INC/INC24 

DEC/DEC24 

CLR/CLR24 

NEG 

ASL/ASR 


F 


~F 




AO 


XO 




AO 


X1 




BO 


YO 




BO 


Y1 




NOT 

ROL/ROR 

LSL/LSR 

F 




No Transfer 






C*1Q 
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DSP56166 Functional Instruction Sat Summary 



INSTRUCTIONS 



BIT FIELD MANIPULATION INSTRUCTIONS 



DSP56166 


OPERATION 


OPERAND 


COMMENTS 


BFTSTH #iiii, 
BFTSTL #iili, 
BFCHG #iiii, 
BFSET #iiii, 
BFCLR #iiii, 


X:(Rn) 


n=[0,3] 


X:<aa> 


First 32 words of X 

memory 

5 bit address 


X:<pp> 


Last 32 words of X 

memory 

5 bit address 


X1,X0,Y1,Y0, 
RO, R1,R2, R3, 
NO, N1,N2, N3 
MQ S M1,M2,M3 
A2, B2, A1,B1, 
AO, BO, A, B 
SR, OMR, SP, SSH, 
SSL, LA, LC 





EFFECTIVE ADDRESS UPDATE 



DSP56166 


OPERATION 


SOURCE 

ADDRESS 

REGISTER 


DESTINATION 
REGISTER 


LEA 


(Rn) 

(Rn) + 

(Rn)- 

(Rn)+Nn 

n=[0,3] 


RO, R1,R2, R3 
NO, N1,N2, N3 



m 



MOTOROLA 
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Instruction Set Summary 






INSTRUCTIONS 



JUMP/BRANCH INSTRUCTIONS 



DSP56166 


OPERATION 


OPERAND 


COMMENTS 


JSR 
JMP 
Jcc 
JScc 


(Rn) 


n=[0,3] 


$xxxx 


16-bit absolute 
address 


BSR 
BRA 
Bcc 
BScc 


(Rn) 


n=[0,3] 


$xxxx 


16-bit absolute 
address 


JSR 


AA 


8-bit absolute 
address [0,256] 


BRA 


aa 


8-bit PC relative 
address 
[-128,+127] 


Bcc 


ee 


6-bit PC relative 
address 
[-32,+31] 



REP and DO INSTRUCTIONS 



DSP56166 


OPERATION 


OPERAND 


COMMENTS 


REP 
DO 


X:(Rn) 


n=[0,3] 


#xx 


8-bit immediate 
short data 


X1,X0,Y1,Y0, 
RO, R1,R2, R3, 
NO, N1,N2, N3 
MO, M1 , M2, M3 
A2, B2, A1,B1, 
AO, BO, A, B 
SR, OMR, SP, SSH, 
SSL, LA, LC 




REPcc 


1 6 conditions 




DO FOREVER 
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DSP56166 Functional Instruction Sot Summary 



INSTRUCTIONS 



SHORT IMMEDIATE MOVE INSTRUCTIONS 


DSP56166 


OPERATION 


DESTINATION 


COMMENTS 


MOVE(I) #xx, 


X1 

xo 

Y1 
YO 


Immediate short 8-bit 
signed data 
(data is put in the least 
significant byte) 



MOVE — PROGRAM and CONTROL INSTRUCTIONS 



DSP56166 


OPERATION 


Source/ 


Destination/ 


COMMENTS 




Destination 


Source 




MOVE(M) 


P:(Rn) 


A, AO, B, BO 






P:(Rn)+ 


XO, X1,Y0,Y1 






P:(Rn)- 








P:(Rn)+Nn 








P:(R2+xx) 






MOVE(M) 


X:(Rn)+ 


P:(Rn)+ 






X:(Rn)+Nn 


P:(Rn)+Nn 




MOVE(C) 


X:(Rn) 


All registers 


X:#xxxx: 




X:(Rn)+ 




Long 16-bit 




X:(Rn)- 




Absolute address 




X:(Rn)+Nn 








X:(Rn+Nn) 




#xxxx: 




X:-(Rn) 




Long 16-bit 




X:#xxxx 




immediate 




#xxxx 




data 




X:(A1) 








X:(B1) 








X:(R2+xx) 






MOVE(C) 


All registers 


All registers 





D 
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DSP56166 Functional Instruction Set Summary 



INSTRUCTIONS 



MOVE ABSOLUTE SHORT AND 
MOVE PERIPHERAL INSTRUCTIONS 



DSP56166 


OPERATION 


Source/ 
Destination 


Destination/ 
Source 


COMMENTS 


MOVE(S) 


X:<aa> 


A,B, 
X0,Y0 


First 32 words of 
X memory 
5 bit address 


MOVE(P) 


X:<pp> 


A, B, 
XO.YO 


Last 32 words of 
X memory 
5 bit address 


X:(Rn)+ 
X:(Rn)+Nn 



TRANSFER WITH PARALLEL MOVE INSTRUCTION 





DSP56166 




OPERATION 


REGISTER TRANSFER 


PARALLEL MOVE 






Source 


Destination 


Source/Dest. 


Destination/ 
Source 




TFR(3) 


A 
B 


X0.X1, 
Y0,Y1 


X:(Rn)+ 
X:(Rn)+Nn 


X0,X1 ,Y0,Y1 , 
AO, BO, A, B 



REGISTER TRANSFER WITHOUT PARALLEL MOVE INSTRUCTION 



DSP56166 


OPERATION 


SOURCE 


DESTINATION 


TFR(2) 


A 
B 


X 
Y 



C*14 
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DSP56166 Functional Instruction S#t Summary 



INSTRUCTIONS 



REGISTER TRANSFER CONDITIONAL MOVE INSTRUCTION 



DSP56166 


OPERATION 


Data ALU 


Address Reg. 


Tec 


A, F 

B, F 

YO, F 
XO, F 


RO, RO 


RO, Rm 



CONDITIONAL PROGRAM CONTROLLER INSTRUCTIONS 



DSP56166 



OPERATION 



BRKcc 



DEBUGcc 



LOGICAL IMMEDIATE INSTRUCTIONS 



DSP56166 



OPERATION 



ORI 
ANDI 



#xx, 
#xx, 



DESTINATION 



CCR 

MR 
OMR 



COMMENTS 



8 bit immediate data 



DOUBLE PRECISION DATA ALU INSTRUCTIONS 



Operation 



DMAC 



MPY(su,uu) 
MAC(su,uu) 



DSP56166 



DATA ALU 
OPERATION 



sign unsign 



Y1, 
X1, 
X1, 
XO, 



XO, F 

Y1, F 

YO, F 

YO, F 



m4 
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Instruction Set Summary 






INSTRUCTIONS 





INTEGER DATA ALU INSTRUCTIONS 


DSP56166 


DATA ALU OPERATION 


Operation 




IMAC 
IMPY 


XO, XO, F 
X1.X0.F 
A1.Y0, F 
B1,X0, F 
Y0.X1, F 
Y1,X1,F 
Y1 , XO, F 
YO, XO, F 









DIVISION INSTRUCTION 



DSP56166 


DATA ALU OPERATION 


Operation 




DIV 


X1,F 
XO, F 
Y1,F 
YO, F 



OTHER DATA ALU INSTRUCTIONS 



DSP56166 


OPERATION 


NORM 


Rn, F 




n=[0,3] 


TST2 


X1,X0,Y1,Y0 




Test data registers 


ADC 


X, F 
Y,F 















iiiiiii 
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DSP561 66 Functional Instruction Sot Summary 



INSTRUCTIONS 



OTHER DATA ALU INSTRUCTIONS 



DSP56166 


OPERATION 


CHKAAU 


Set V,N,Z according to last address 
ALU operation 


ZERO F 


Zero F from bit 32 to 39 


EXT F 


Sign extend F from bit 31 to 39 


SWAP F 


Swap F1 and FO 


NEGC F 


Negate with borrow 


ASL4 F 




ASR4 F 




ASR16 F 


Move A,A0 arithmetic 



OPERATION 



WAIT 



STOP 



ENDDO 



RESET 



RTS 



RTI 



SWI 



DEBUG 



NOP 



SPECIAL INSTRUCTIONS 



DSP56166 



H 
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DSP56166 Core Programming Sheet 



1 



Application: . 



Date:. 



Programmer: 



Sheet 1 of 4 



CORE 



Program Memory Wait States 

Set to zero for fist memory. 



Data Memory Wait States 

Set to zero for fast memory; 



Bus State Status — Read Only 

- DSP NOT a Bus Master 

1 s DSP a Bus Master 



Bus Request Hold 

= BR Asserted By External 

1 s BR Always Asserted 



Port A 

Bus Control Register (BCR) 
X:$FFDE Read/Write 
Reset = $43FF 



15 14 13 12 11 10 ^9 8 



BS 



X3 



7 6 5" "4 



3 2 10" 



External Peripheral Wait States 

Set to zero for fast memory. 



Port A 

Bus Control Register 2 (BCR2) 
X:$FFDA Read/Write 
Reset = $001 F 



15 


14 


13 


12 


11 


'1"0 


9 


8 


"7" 


"6" 


5 


>4 


"3" 


2 


1 


fr 








* 




* 




* 















* 




* 




P4 


P3 


P2 


P1 

i'% 
••J 


PO 

y 












Carry 

Overflow 



Negative 

Unnormalized 
Extenston — - 
Limit- — — 



Sticky Bit 

Interrupt Mask 
Scaling Mode - 
ForeVerFlag — 
Loop Flag — — 



Status Register (SR) 
Read/Write 
Reset - $0300 



f t k^^^^A^ ftfttftt 

15 14 13 12T1 10 N/ 9 ET 7 6 5 4 3 2 1 



PR 



m*m?- 



CCR 

* = Reserved, Program as zero 



:mm 



'Wi^^^^^iNiwraiHP 
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DSP56166 Core Programming Sheet 



mk 



Application: 



Date: 



Programmer: 



Sheet 2 of 4 



CORE 



tROAMode 






IAL1 IAL0 


Enabled 


IPL 




IAL2 


trigger 








1 

1 

1 1 


No; 
Yes 
Yes 
Yes 


:f: : 1 ; : : -i :: - : 




■■ : !:!1U' 


Level 
Neg, Edge 




















IRQB 


Moc 


ie 






IBL1 1BL0 


Enabled 


IPL 




IBL2 


Triqqer 






1 

1 

1 1 


No 
Yes 
Yes 
Yes 




i 1 :■ 
2 




Level 
Neg. Edge 








i 














Codec IPL 

= Lowest Level 
3 = Unmaskable 








v^^-iWi? 






Host IPL 

= Lowest Level 
3 * Unmaskable 








4 : .-l ; :- : :: : >::! 






SS10 IPL 

= Lowest Level 
3 * Unmaskable 








& y^'.-3 






SSI1 IPL 

= Lowest Level 
3 = Unmaskable 








!-:: ::: ::i':.:-i.x';:? 






Timer IPL 

* Lowest Level 




u 


3 = Unmas 


kable 








I 



Interrupt Priority Register (IPR) 
X:$FFDF Read/Write 
Reset = $0000 



'15 14 v 13 



TL1 



TLO S1 L1 S1 L0 S0L1 SOLO HL1 



HLO CL1 



CLO IBL2 IBL1 IBLO IAL2 IAL1 IAL0 



■i 
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iSiisiii pRiGiiwMiNl iHllisi 



C - 10 






Application: 



Date: 

Programmer: 



Sheet 3 of 4 



core! 



iROiWtocte 



iiiil 


Mill 


Enabled 


IHS 





. 1 

ills 


mmm 
1 



.1 


Not enabled 
Level 

Not enabled 
Neg. Edge 


1 

: 1 



Interrupt Priority Register 20PR2) 
X:$FFDD Read/Write 
Reset = $0000 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 

















* 






* 




* 




"IT 




* 




ICL2 


ICL1 








* 


















*.= Reserved, Program as zero 
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DSP56166 Core Programming Sheet 



Application: 



Date: 



Programmer: 



Sheet 4 of 4 



CORE 



IRQCMode 



IGL2 


iem 


Enabled 


IPL 





1 

■i-i-l-iv 


■I-: Of ■:■■■:.■: 

Mm- 


Not enabled 
Level 

Not enabled 
Neg. Edge 


1 i 



Interrupt Priority Register 20PR2) 
X:$FFDD Read/Write 
Reset = $0000 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 





* 




* 













* 






* 




* 




* 




ICL2 


ICL1 


* 







* 



* 















Operating Mode 

00 3= Boot: Byte-wide at P:$CG00 

01 = Boot: Host or SSI0 

1 =s Int. Mem; Reset at P:$E000 

11 s Ext. Mem: Reset at P:$Q0QQ 



Bus Arbitration Mode 

= Slave 

1 .= Master 



External X Memory 

= Internal X Memory enabled 

1 = Internal X Memory disabled 



Saturation 

- Disable 

1 •= Enable 



Rounding 

= Convergent Rounding 

1 s Two's Complement Rounding 



Stop Delay 

= 524KT Stabilization 

1 = 28 T Stabilization 



Clock Out 

s Cloak on CLKO Pin 

1 = Disable 



Operating Mode Register (OMR) 

Read/Write 

Reset = $000x 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


' 1 


s 





* 




* 







* 



* 



* 




* 




CD 


SD 


R 


SA 


EX 


MC 


MB 


MA 













* = Reserved, Program as zero 
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DSP56166 Phase Looked Loop Programming Sheet 



Application: 



Date: . 



Programmer: 



Sheet 1 of 1 



P.L.L. 



Clockout Se ect 



CS1 CSO 



CLKOUT 



PHO 

Reserved 

Squared F ext 

Squared F exr r2 



Phase Select Bit 

» ID divider bypassed 

1 = ID divider used 



PLL Power Down 






0-Off 
1 - On 








PLL Enabie 

- Disable 

1 « Enable 








III? 






VCO Lock -Read Only 

^ NOT Locked 

1 -Locked 








ii 




• , 



PLL Control Register 1(PLCR1) 
X:$FFDC Read/Write 
Reset = $0000 



15 


14 


13 


12 


'11 


10' 


9 


8 


7 


6 


5 


4 


3 


2 


1 





Lock 


PLLE 


PLLD 


PS 


CS1 


CSO 





* 




* 







* 










* 






* 














Feedback Divider 

Multiplies Clock Frequency by any value from 1 to 256 



Input Divider 

Divides Clock Frequency by 1 to 1 6 



Power Down Bits 

Divid e by any power of 2 between 2° and 2 15 [ ~1 



PLL Control Register (PLCR0) 
X:$FFDD Read/Write 
Reset = $0000 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 





PD3 


PD2 


PD1 


PD0 


ID3 


ID2 


ID1 


I DO 


YD7 


YD6 


YD5 


YD4 


YD3 


YD2 


YD1 


YD0 











* « Reserved, Program as zero 
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DSPS6166 Phase Looked Loop Programming Sheet 



P.LL 




EXTAL 



CSI^CSO + 



IP3-ID0; 
-1 to -f 16 
4-bit Divider 

PS=0 P$==1 



_J*\IW 



PHASE 
COMP. 



Filter 



VCO 



PD3>PD0 ;,.; 
-f \+& to + £}*[ +* 



PLLE=1 



4-bit Power of 2 Divider \_ 



k; / ■ YP7-YD Q 

-— - jr 1 tO r 256] ^— — ^ 

8-bit PLL Down Counter 



Fosc 



PLLE=0 ; 



mm 
On-chip Frequency Synthesis Control/Status Register (PCR1) ADDRESS X:$FFDC 



Internal Phase PHQ 



15 I 14 I 13 I 12 


I 11 I 10 I 


9 i 8 


|7 


i 6 1 


5 | 4 


|"3 


I 2 ' 


i 1 


i ° , 


| LOCKJPLLE PLLD | PS 


|CS1 CSO 


** ** 


** 


** 


** ** 


** 


** 


** 


** i 



LOCK 



PLLE PLLD 



Phase 
Select 



CS1-CS0 
CLKO 
Select 



00 
01 
10 
11 



00 



01 
10 
11 



PLL unlocked 
PLL locked 



PLL active but not used as Fosc 
PLL powered down 
PLL active and used as Fosc 
Reserved 



Squared EXTAL selected as Fosc if PLLE=0 
Squared EXTAL/ID selected as Fosc if PLLE=0 



PHQ output to CLKO when enabled by the CD bit (bit 7) of the OMR 



Reserved 



Fext output to CLKO when enabled by the CD bit (bit 7) of the OMR 



Fext/2 output to CLKO when enabled by the CD bit (bit 7) of the OMR 



On-chip Frequency Synthesis Control/Status Register (PCR0) 

y 15 14 13 12 [ 11 | 10 | 9J1 \ 7 6 5 4 



PD3 PD2 PD1 PD0 ID3 ID2 ID1 ID0 YD7 YD6 YD5 YD4 



ADDRESS X:$FFDB 

3 2 10; 



YDS YD2 YD1 YD0 



PD3-PD0 
Clock 
Output 
Divider 


$0 


Divide the VCO output clock by 1 (2°) 


8 


Divide the VCO output clock by 256 (2 8 ) 


$1 


Divide the VCO output clock by 2 (2 1 ) 


9 


Divide the VCO output clock by 51 2 (2 9 ) 


$2 


Divide the VCO output clock by 4 (2*) 


A 


Divide the VCO output clock by 1 024 (2 1U ) 


$3 


Divide the VCO output clock by 8 (2 3 ) 


B 


Divide the VCO output clock by 2048 (2 11 ) 


$4 


Divide the VCO output clock by 16 (2 4 ) 


C 


Divide the VCO output clock by 4096 (2 1Z ) 


$5 


Divide the VCO output clock by 32 (2 5 ) 


D 


Divide the VCO output clock by 81 92 (2 13 ) 


$6 


Divide the VCO output clock by 64 (2 6 ) 


E 


Divide the VCO output clock by 16384 (2 14 ) 


$7 


Divide the VCO output clock by 1 28 (2 7 ) 


F 


Divide the VCO output clock by 32768 (2 15 ) 


ID3-ID0 
Input 
Clock ' 
Divider 


$0 


Divide the input clock by 1 


8 


Divide the input clock by 9 


$1 


Divide the input clock by 2 


9 


Divide the input clock by 1 


$2 


Divide the input clock by 3 


A 


Divide the input clock by 1 1 


$3 


Divide the input clock by 4 


B 


Divide the input clock by 12 


$4 


Divide the input clock by 5 


C 


Divide the input clock by 13 


$5 


Divide the input clock by 6 


D 


Divide the input clock by 14 


$6 


Divide the input clock by 7 


E 


Divide the input clock by 1 5 


$7 


Divide the input clock by 8 


F 


Divide the input clock by 16 


YD7-YD0 
VCO 
Down 

Counter 
Value 


$YD 


Multiplies by YD+1 







On-chip Frequency Synthesizer Programming Model 
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lliit 66 Timer Programming Sheet 



Application: 



Date: . 



Programmer: 



Sheet 1 of 1 



Timer 



Timer Output Enable : 

d£K)i : TOUTDisat)ie<i : ; 
001 s Compare/Overflow Pulse 
010 ^Overflow Pulse 
;0il:= Compare Pulse '. : 
: 1 60; = Overflow/Compare Toggle 
;1 01; = Compare/Overflow Toggle 
110 ^Overflow Toggle ■ 
i.1!J 1 i= : Compare Toggle .;. . ,i 



Inverter Bit 

= Do NOT Invert TIN Pin Signal : 
.it = fnyert TIN Pih $l^nai ; 



Timer Enable ; 

= Disable Timer 

1 is Enable Timer 



Timer Control Register (TCR) 
X:$FFEC Read/Write 
Reset = $0000 



Compare Interrupt Enable 

0s Disable interrupt 

1 s Interrupt DSP after TCTR = TCPR 



Overflow Interrupt Enable 

= Disable interrupt 

1 s Interrupt DSP when TCTR = 



Event Select 

s Fosc/2 is event dock 

1 s.TIN is event clock '. 



Decrement Ratio 

(Count Register Presoaler) 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 





TE 


INV 


T02 


T01 


TOO 


CIE 


OIE 


ES 


DC7 


DC6 


DC5 


DC4 


DC3 


DC2 


DC1 


DC0 











Timer Count Register (TCTR) 
X:$FFED Read/Write 
Reset = $0000 



Count — Decremented when TPR •= 



"15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



Compare Value — Compare with Count Register 



Timer Compare Register (TCPR) 
X:$FFEE Read/Write 
Reset = $0000 



15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 



Number to toad into Count Register 



timer Preload Register (TPR) 
X:$FFEF Read/Write 
Reset = $0000 



"15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 
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DSPS6166 Codec Programming Sheet 



Application: 



Date: 



Programmer: 



Sheet 1 of 2 



Codec 



Input Select 

= MIC Selected 
1= AUX Selected 



Codec Enable 

= Disabled 
■yM. ^Enable n: 



Codec Interrupt Enable 

= Disabled 

1 = Enabled 



Microphone Gain 
Select Bits 

00= -6dB 
01 = OdB: 
10= 6dBi 
1i:=17dB : i 



Codec Loop Back Bit 

= Normal operation 

1 = A/D mod; input O/A mod. 



dock Select Bit 

= Squared Fext as Input Clock 

1 a PLL output as Input Clock 




Mute Bit 

% Output Muted 
-Output NOT Muted 



Audio Level Control Bits 


:0000 = -15dB 


1000= 5dB 


■0001 =-10dB 


1001 = 11 dB 


0010= -5dB 


1010= 17dB 


0011 = OdB 


1011 = 23dB 


0100= 5dB 


1100= 29dB 


0101 = 11dB 


1101 = 35dB 


0110= 17dB 


1110= 35dB 


0111 = 23dB 


1111 = 40dB 


:■■■■■■:■ >S.; . : 



Codec Control Register 1(COCR1) 
X:$FFC8 Read/Write 
Reset - $0000 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 





COIE 


COE 


INS 


MGS1 


MGSO 


MUT 


* 




CLS 


CLB 


* 




* 







VC3 


VC2 


VC1 


vco 











Codec Ratio Select Bits 

Select any decimation/interpolation 
ratio values between 65 to 1 28 ; 



Input Divider Bits 

Divide the input clock to the codec by 
any value between 1 and 64 



Codec Control Register (COCR0) 
X:$FFC7 Read/Write 
Reset = $0000 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 





* 







CRS5 


CRS4 


CRS3 


CRS2 


CRS1 


CRSO 


* 




* 




ED5 


ED4 


ED3 


ED2 


ED1 


EDO 











* = Reserved, Program as zero 



H 
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Application: 



Date: 

Programmer: 



Sheet 2 of 2 



I Codec 



Codec Status Register (CbSR) 
X:$FFE8 Read Only 
Reset = $04 



Codec Transmit Data Empty ; 

= Wait 

1 = Writ© Data 



Codec Receive Data Full 

OsWait 

1 =t Read Data 



Codec Transmit Uhderrun Error Flag 

1 a Error . 



Codec Receive Overrun Error Flag 

= OK 

1 a Error 



7 6 5" 43 2 1 



CRDF CTDE CROE CTUE 



Transmit Data Register (CTX) 
X:$FFE9 Write Only 
Reset = $0000 



Load Under Program Control 



15 14 13 12 11 10 9 8 7 6 5 4 """"""3 2 1 



Read Under Program Control 



Receive Data Register (CRX) 
X:$FFE9 Read Only 
Reset = $0000 



15 14 13 12 11 10 9 8" 7 6 5 "4 3 2 1 CM 



ic « Reserved, Program as zero 
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I/O Programming Sheet 



Application: 



Date: . 



Programmer: 



Sheet 1 of 2 



GPI/O 



PortB 



Port B Control 

= General Purpose I/O 

1 s Host Interface 



PortB 

Control Register (PBC) 
X:$FFC0 Read/Write 
Reset = $0000 
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* 










* 



* 
















BC 

















Port Data Direction Control 

= Input 

1 s Output 



w 



PortB 

Data Direction Register (PBDDR) 

X:$FFC2 Read/Write 

Reset = $0000 



15 


14 


13 
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* 




DB14 


DB13 


DB12 


DB11 


DB10 


DB9 


DB8 


DB7 


DB6 


DB5 


DB4 


DB3 


DB2 


DB1 


DB0 











Port B Data (usually loaded by program) 



PortB 

Data Register (PBD) 
X:$FFE2 Read/Write 
Reset = $0000 
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PB14 


PB13 


PB12 


PB11 


PB10 


PB9 


PB8 


PB7 


PB6 


PB5 


PB4 


PB3 


PB2 


PB1 


PB0 1 
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* = Reserved, Program as zero 
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DSP56166 



General 



Purpose I/O Programming Sheet 



i 



Application: 



Date: 



Programmer: 



Sheet 2 of 2 



GPI/O 



PortC 



Port C Pin Control 

a General Purpose I/O Pin 

1 a Peripheral Pin 



PortC 

Control Register (PCC) 
X:$FFC1 Read/Write 
Reset = $0000 
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1 
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CC11 


CC10 


CC9 


* 




CC7 


CC6 


CC5 


CC4 


* 




CC2 


CC1 


ceo 












Port C Data Direction Control 

a Input 

1 a Output 



PortC 

Data Direction 
Register (PCDDR) 
X:$FFC3 Read/Write 
Reset - $0000 
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12 


Tf 
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* 




DC11 


DC10 


DC9 


* 




DC7 


DC6 


DC5 


DC4 





DC2 


DC1 


DCO 












Port C Data (usually loaded by program) 



PortC 

Data Register (PCD) 
X:$FFE3 Read/Write 
Reset = $0000 
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12 


^Trfo 1 8 
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3 2 7~1T 
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PC11 


PC10 


PC9 


* 




PC7 


PC6 


PC5 


PC4 


* 



PC2 


PC1 


PCO 
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Programming Sheet 



Application: . 



Date:. 



Programmer: 



Sheet 1 of 4 



HOST 



PortB 



Port B Control 

Os General Purpose I/O 
1 s Host Interface 



PortB 

Control Register (PBC) 
X:$FFC0 Read/Write 
Reset = $0000 
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* 










* 












* 






















BC 
1 











1 



HOST -DSP SIDE 



Host Receive Interrupt Enable 

s Disable 1 = Enable — Interrupt on HRDF 



Host Transmit Interrupt Enable 

: ;s disable 1 a Enable — Interrupt on HTDE 



Host Command Interrupt Enable 

a Disable ; 1 = Enable— Interrupt on HOP 



Host Flags 

General Purpose Read/Write Flags 



Host Control Register (HCR) 
X:$FFC4 Read/Write 
Reset = $00 
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3 s 


2 


1 
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HF3 


HF2 


HCIE 


HTIE 


HRIE 







* - Reserved, Program as zero 
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Sheet 



Application: 



Date: 



Programmer: 



Sheet 2 of 4 



HOST 



HOST -DSP SIDE 



Host Status Register (HSR) 
X:$FFE4 Read Only 
Reset = $02 



Host Receive Data Full 

= Wait 1 = Read 



Host Transmit Data Empty 

= Wait 1 = Write 



Host 'ending 

= Wait 1= Ready 



Host Flags 

Readonly 



DMA Status (Read Only) 

= Disabled 1 = Enabled 
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M 


3 N 


2 


1 





DMA 


* 







HF1 


HFO 


HCP 


HTDE 


HRDF 







Host Receive Data (usually Read by program) 



Host Receive Data Register (HRX) 
X:$FFE5 Read Only 
Reset = $xxxx 
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HIGH BYTE 


LOW BYTE 











































Host Transmit Data (usually loaded by program) 



Host Transmit Data Register (HTX) 
X:$FFE5 Write Only 
Reset = $xxxx 
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HIGH BYTE 


LOW BYTE 
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|SSI^1lB6 Host Programming Sheet 



Application: 



Date: 



Programmer: 



Sheet 3 of 4 



HOST 



HOST - HOST PROCESSOR SIDE 



Interrupt Control Register (ICR) 
$0 Read/Write 
Reset = $00 



Receive Bequest Enable 

DMA Off = Interrupts Disabled 1 = Interrupts Enabled 

DMAOn 0;=Hosf->DSP 1=OSP->Host 



Transmit Request Enable 

DMA Off = Interrupts Disabled 1 :* Interrupts Enabled 

DMAOn = DSP-*H0st 1sHost->DSP 



WriteOnly . 














Host Mode Control 

00* DMA Off 01=Mlea*l 
10* 16 Bit DMA 11*8 Bit DMA 








llfilfir 






Initialize (Writ* Only) 

* No Action 1 = initialize DMA 








, ■ ' :< 







INIT HM1 HMO HF1 



TREQ RREQ 



Command Vector Register (CVR) 
$1 Read/Write 
Reset = $16 



Host Vector 

Executive Interrupt Routine 0-63: 



Host Command 

= Wle : 1= Interrupt DSP 
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HC 





HV5 


HV4 


HV3 


HV2 


HV1 


HVO I 
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DSP56166 Host Programming Sheet 



Application: 



Date: . 



Programmer: 



Sheet 4 of 4 



HOST HOST - HOST PROCESSOR SIDE 



interrupt Status Register (!SR) 
$2 Read/Write 
Reset ~ $03 



[Receive Data Register Bull 

* Wait 1 = Read 



ster Em pty 

s Walt .1= Write 



Transmitter Ready 

= Data in HI 1 = Data Not in Hi 



Host Rags 






ReadOnly 








: : D3«^Status::; : ;:i ■; ; 
0i DMA Disabled 1 = DMA .E nabled 




£■£ '£■*££? 






^ost^Request : ^ -6; 
a HREQ Deasserted t-« HREQ Asserted 




• ~ T 


B 



m:^<mm 



7 


6 
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/ A 


3 s 


2 


1 





HREQ 


DMA 


* 




HF3 


~wr 


TRDY 


TXDE 


RXDF 







interrupt Vector Register (IVR) 
$3 Read/Write 
Reset = $0F 



Receive Byte Registers 
$6, $7 Read Only 
Reset = $xxxx 



Transmit Byte Registers 
$6, $7 Write Only 
Reset = $xxxx 



Exception vector number for use by NSC680OO 
processor family vectored interrupts. 



n 
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5 


4 


3 


2 


1 


(T 


IV7 


IV6 


IV5 


IV4 


IV3 


IV2 


IV1 


IVO 







Host Receive Data (usually read by program) 



15 14 13 12,11 10 9 


8 


7 


6 5 4(321 


If 


HIGH BYTE 


LOW BYTE 


































Host Transmit Data (usually lo 


aded by program) 


15 14 13 12 ill' 10 9 8 
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6 5 4 i 3 2 -PT 


HIGH BYTE 


LOW BYTE 



































it- - Reserved, Program as zero 
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DSP56166 RSSI Programming Sheet 



Application: 



Date: 



Programmer: 



Sheet 1 of 3 



RSSI 



RSSI Port C Pin Control 

= General Purpose I/O Pin 

1 = RSSI Pin 



PORTC 

RSSI Control Register (PCC) 
X:$FFC1 Read/Write 
Reset = $0000 
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CC11 


CC10 


CC9 





CC7 


CC6 


CC5 


CC4 





CC2 


CC1 


ceo 












RSSI Receive Data (usually read by program) 



RSSI Serial Receive Register 
RSSI0 Address X:$FFF1 Read Only 
RSSI1 Address X:$FFF9 Read Only 
Reset = $xxxx 



T5~T4 13 12|il 10 1 
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6 5 4 i 3 2 1 


HIGH BYTE 


LOW BYTE 











































RSSI Transmit Data (usually loaded by program) 



RSSI Serial Transmit Register 
RSSI0 Address X:$FFF1 Write Only 
RSSI1 Address X:$FFF9 Write Only 
Reset = $xxxx 



15 


14 


13 


12 


11 


10 


9 


8 


7 


6 


5 


4 


3 


2 


1 


0~ 


HIGH BYTE 


LOW BYTE 











































* « Reserved, Program as zero 



MOTOROLA 



DSP56166 PROGRAMMING SHEETS 



O * 33 



/Sfl 



DSP56166 RSSi Programming 



Application: 



Date: 



Programmer: 



Sheet 2 of 3 



RSSI 



Word Length Control 

00 = 8 Bits/Word 

01 = Reserved 

10 = 12 Bits/Word 

11 a 16 Bits/Word 



iter Range 

0=/1 

i=/a 



RSSI Control Register A (CRA) 
RSSIO Address $FFD0 Read/Write 
RSSI1 Address $FFD8 Read/Write 
Reset = $0000 



frame Date Divider Control 

000 = 1 
111 =8 



H 



Prescale Modulus Select 



15 


14 


13 


12 


11 


10 
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1 





PSR 


WL1 


WLO 


* 







DC2 


DC1 


DCO 


PM7 


PM6 


PM5 


PM4 


PM3 


PM2 


PM1 


PMO 











Clock Source Direction 

= External Clock 1 a Internal Clock 



Clock Polarity 

.0 a Data Out t, Data In I 1 = Data Out l t Data In t 



MSB Position 

= MSB First 



1 * LSB First 



Frame Sync Length 

= Word Syno 1 = Bit Sync 



Frame Sync Invert 

= Active High 1 = Active Low 



Enable Bit 

= RSSI Disable 1 a RSSI Enable 



Mode Select 

a Normal 1 = Network 



Transmit Enable 

= Disable 1 = Enable 



j Receive Enable 






j o a Disable 1 a Enable 






| Transmit Interrupt Enable 






[Oa Disable 1 a Enable 




Hit 




| Receive Interrupt Enable 


j a Disable 1 a Enable 


I 




\ \ 



FS Direction Bit: 

: a FS Input 
1 a FS Output 



Gated Clock Bit: 

a Continuous Clock 

1 = Gated Clock 



early FS Bit: 

a FS on the first bit 

1 a FS one bit earlier 



RSSI Control Register B (CRB) 
RSSIO Address $FFD1 Read/Write 
RSSI1 Address $FFD9 Read/Write 
Reset = $0000 
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RIE 


TIE 


RE 


TE 


MOD 


SSIEN 


FSI 


FSL 


SHFD 


SCKP 


SCKD 


FSD 


GCK 


ELFS 


* 
















* = Reserved, Program as zero 
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DSP56166 RSSI Programming 



Application: 



Date: 



Programmer: 



Sheet 3 of 3 



RSSI 



Transmit/Receive Frame Sync 

?: Wait 1 = ReadRX 



Transmitter Underrun Error 

DsOK 1 = Error 



Receiver Overrun Error 

0= OK 1:= Error 












Transmit Data Register Empty 

% Wait 1 = Write 








■ \ 






Receive Data Register Full 

;= Wait 1 = Read 


EtfiS 




I J 



RSSI STATUS REGISTER (SSISR) 
RSSIO ADDRESS $FFF0 Read Only 
RSSI1 ADDRESS $FFF8 Read Only 
Reset = $00 
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3 
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1 





RDF 


TDE 


ROE 


TUE 


TRFS 





* 











H 



* = Reserved, Program as zero 



liiiiililf 



DSPS6166 PROGRAMMING SHEETS 



iiiiii 



C - 36 DSP561 66 PROGRAMMING SHEETS MOTOROLA 



W 



DSP56166 User's Manual Trouble Report 

DSP Applications Fax Number — (512) 891-4665 
Dr. BuB Bulletin Board — 891-DSP3 (8 data bits, no parity, 1 stop) 

We welcome your comments and suggestions. They help us provide you with better prod- 
uct documentation. Please send your suggestions/corrections to the Fax number or Email 
address above or mail this completed form to: 

Motorola Inc. 

6501 Wm. Cannon Drive West 

Austin, Texas 78735-8598 

Attn: Digital Signal Processors Documentation 



1 . Did you find errors in the manual? Please give page number and a description of 
each error. 




DSP56166 User's Manual Trouble Report 



2. Did you find the manual clear and easy to use? Please comment on specific 
sections that you feel need improvement. 



3. What sections of this manual do you consider most important/least important. 
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— A— 

A0-A15 2-3 

Address Bus 2-3 

Address Registers 1-9 

Analog Ground 2-11 

AUX 2-15 

Auxiliary Input 2-15 

— B— 

BB 2-9 

BG 2-8 

Bit Field Manipulation Instructions . .C-1 1 

Bootstrap Control Logic 3-7, A-3 

Bootstrap Example, Low Cost B-2 

Bootstrap Firmware Program A-4 

Bootstrap from the External P Memory A-5 

Bootstrap from the HI A-7 

Bootstrap from the SSIO A-6 

Bootstrap Mode 3-7 

Bootstrap Program 3-8 

Bootstrap Program Listing A-5 

Bootstrap ROM 3-7, A-3 

BR 2-7 

BS 2-5 

Bus Busy 2-9 

Bus Control Register 4-3, 4-6 

Bus Control Register (BCR) C-1 8 

Bus Grant 2-8 

Bus Request 2-7 

Bus Strobe 2-5 

— C— 

CCR 1-21 

CIE 7-7 

CLKO 2-11 

Clock Output 2-11 

Clock Synthesis Control Register 9-4, 9-5 

Codec Control Register (COCR) C-25 

Codec Status Register (COSR) C-26 

Command Vector Register 5-7 

Command Vector Register (CVR) . . .C-31 



Condition Code Register 1-21 

Conditional Program 

Controller Instructions C-1 5 

Control Register (PBC) C-27, C-29 

Control Register (PCC) C-28 

CS1-CS0 9-5 

CVR Host Command Bit 5-9 

CVR Host Vector 5-7 

— D— 

D0-D15 2-3 

Data ALU Instructions C-1 6 

Data ALU Instructions 

with One Parallel Operation . . C-9 

Data Bus 2-3 

Data Direction Register (PBDDR) . . C-27 
Data Direction Register (PCDDR) . . C-28 

Data Register (PBD) C-27 

Data Register (PCD) C-28 

DC7-DC0 7-6 

Debug Request Input 2-14 

Debug Serial Clock/Chip Status 1 . . 2-14 
Debug Serial Input/Chip Status . . . 2-14 

Debug Serial Output 2-14 

Division Instruction C-1 6 

DMA 5-12,5-17 

DMA Mode Operation 5-18 

Double Precision 

Data ALU Instructions C-1 5 

DR 2-14 

DSCK/OS1 2-14 

DSI/OSO 2-14 

DSO . . . 2-14 

DSP Programmer Considerations . . 5-23 

DSP to Host 5-20, 5-21 

Dual Read Instructions C-8 

— E— 

Effective Address Update C-1 1 

ES 7-6 

Exception Priorities within an IPL . . . 1-13 
EXTAL 2-11 
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Index (Continued) 



mm 



External Clock/Crystal Input 2-11 

External Filter Capacitor 2-11 

Fractional Arithmetic .1-8 

G Bus Data 1-31 

GDB 1-4 

Global Data Bus . . . .1-4 

GNDS ..2-10 

H0-H7 .2-11 

HAO-2 2-1 1 

HACK ..2-12 

HC . 5-9 

HCIE 5-10 

HCP 5-11 

HCR 5-9 

HCR Host Command 

Interrupt Enable 5-10 

HCR Host Flag 2 5-10 

HCR Host Flag 3 .5-10 

HCR Host Receive Interrupt Enable . 5-10 
HCR Host Transmit Interrupt Enable 5-10 

HEN 2-12 

HF0 ....... . . 5-12,5-13 

HF1 5-12,5-14 

HF2 ..... 5-10,5-17 

HF3 ..... . 5-10,5-17 

HI 5-3 

HI Programming Model 5-5 

HM1.HM0 5-14 

Host Acknowledge 2-1 2 

Host Address 0-2 2-11 

Host Bootstrap Example B-2 

Host Control Register 5-9 

Host Control Register (HCR) C-29 

Host Data Bus 2-11 

Host Enable 2-12 



Host Interface 1-16, 5-3 

Host Port Usage 5-21 

Host Programmer Considerations . . 5-21 

Host Read/Write 2-11 

Host Receive Data Register 5-6 

Host Receive Data Register (HRX) . C-30 

Host Request 2-12 

Host Status Register 5-11 

Host Status Register (HSR) ....... C-30 

Host to DSP 5-19 

Host Transmit Data Register 5-5 

Host Transmit Data Register (HTX) . C-30 

HR/W 2-11 

HRDF 5-11 

HREQ .............2-12,5-17 

HRIE.. 5-10 

HRX 5-6 

HSR DMA Status 5-12 

HSR Host Command Pending 5-11 

HSR Host Flag 5-12 

HSR Host Flag 1 5-12 

HSR Host Receive Data Full 5-11 

HSR Host Transmit Data Empty ... 5-11 

HTDE 5-11 

HTIE 5-10 

HV 5-7 

— I— 

I/O Port Set-up 4-3 

ICR 5-12 

ICR Host Flag 5-13 

ICR Host Flag 1 ................ 5-14 

ICR Host Mode Control 5-14 

ICR initialize Bit 5-15 

ICR Receive Request Enable 5-12 

ICR Transmit Request Enable 5-13 

ID3-ID0 9-5 

INIT 5-15 

Instruction Set Summary C-5 

Integer Data ALU Instructions C-16 

Integer Operations 1-8 

Interrupt Control Register 5-12 

Interrupt Control Register (ICR) C-31 



INDEX- 4: 
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Interrupt Priority Levels 1-13 

Interrupt Priority Register 

(IPR) 1-12, C-1 9, C-20.C-21 

Interrupt Priority Structure 1-10 

Interrupt Status Register 5-15 

Interrupt Status Register (ISR) C-32 

Interrupt Vector Register 5-17 

Interrupt Vector Register (IVR) C-32 

Interrupts Starting Addresses 

and Sources C-4 

INV 7-7 

IPL 1-13 

ISR 5-15 

ISR DMA Status 5-17 

ISR Host Flag 2 5-17 

ISR Host Flag 3 5-17 

ISR Host Request 5-17 

ISR Receive Data Register Full .... 5-16 
ISR Transmit Data Register Empty . . 5-16 

ISR Transmitter Ready 5-16 

IVR 5-17 

IVR Host Interface Interrupts 5-18 



Jump/Branch Instructions C-1 2 

— L— 

Linear 1-9 

LMS Instruction C-9 

Logical Immediate Instructions C-1 5 



-MI- 



MAC 1-6 

MC68020 1-17,5-3 

MIC 2-15 

Microphone Input 2-15 

MODA/IRQA 2-9 

MODB/IRQB 2-9 

MODC/IRQC 2-10 

Mode 3-7 

Mode 1 3-7 



Mode Register 1-21 

Mode Select A 

/External Interrupt Request A . 2-9 
Mode Select B 

/External Interrupt Request B . 2-9 
Mode Select C 

/External Interrupt Request C 2-10 

Modifier Registers 1-9 

Modulo 1-9 

Move — Program 

and Control Instructions .... C-1 3 
Move Absolute Short Instructions . . C-1 4 

Move Peripheral Instructions C-1 4 

MR 1-21 

Multiply-Accumulator 1-6 

— O— 

Offset Registers 1-9 

OIE 7-6 

On-chip Frequency Synthesizer 

Programming Model C-23 

Opcode 1-31 

Operands 1-31 

Operating Mode Register (OMR) . . . C-21 
Other Data ALU Instructions C-1 7 

— P— 

PBC 4-7 

PBD 4-7 

PBDDR 4-7 

PCC . 4-7 

PCDDR 4-7 

PCRO 9-4 

PCRO Feedback Divider Bits 9-4 

PCRO Input Divider Bits 9-5 

PCRO Power Divider Bits 9-5 

PCR1 9-5 

PCR1 CLKO Select Bits 9-5 

PCR1 Phase Select Bit 9-6 

PD3-PD0 9-5 

PDB 1-4 

PEREN 2-5 
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Peripheral Enable 2-5 

Peripherals Memory Map C-3 

Pin Allocations 2-3 

PLL Control Register (PLCR) C-22 

Port B 4-7 

Port B Control Register (PBC) 4-7 

Port B Data Direction Register 4-7 

Port B Data Register 4-7 

Port C 4-7 

Port C Control Register 4-7 

Port C Data Direction Register 4-7 

Port C Data Register 4-7 

Port C Data Register (PCD) 4-7 

Port Registers 4-6 

Power Supply Input 2-11 

Program/Data Memory Select 2-3 

PS 9-6 

PS/DS .2-3 

— R— 

R/W 2-5 

RD . . . 2-5 

Read Enable 2-5 

Read/Write 2-5 

Receive Byte Registers 5-5, C-32 

Receive Data Register (CRX) C-26 

Register Transfer Conditional 

Move Instruction C-15 

Register Transfer without Parallel 

Move Instruction C-14 

REP and DO Instructions C-12 

RESET 2-10 

Reset 2-10 

Reset Circuit B-4 

Reverse Carry 1-9 

RREQ 5-12 

RSSIO Receive Data . 2-13 

RSSIO Serial Clock 2-13 

RSSIO Transmit Data 2-13 

RSSI1 Receive Data 2-13 

RSSI1 Serial Clock 2-13 

RSSI1 Transmit Data 2-13 

RXDF 5-16 



— S— 

SCK0/PC2 2-13 

SCK1/PC7 2-13 

Serial Frame Sync 2-13 

Serial Frame Sync 1 2-13 

SFS0/PC4 2-13 

SFS1/PC9 2-13 

Short Immediate Move Instructions . C-13 

Speaker Negative Output 2-15 

Speaker Positive Output 2-15 

Special Instructions C-1 7 

SPKM 2-15 

SPKP 2-15 

SRD0/PC1 2-13 

SRD1/PC6 2-13 

SSI Control Register (PCC) C-33 

SSI Control Register A (CRA) C-34 

SSI Control Register B (CRB) C-34 

SSI Serial Receive Register C-33 

SSI Serial Transmit Register C-33 

SSI Status Register (SSISR) C-35 

Status Register (SR) C-18 

STD0/PC0 2-13 

STD1/PC5 2-13 

SXFC 2-11 

Synthesizer Ground 2-10 

Synthesizer Power 2-10 

System Stack (SS) 1-22 

TA . . . 2-7 

TCR Compare Interrupt Enable 7-7 

TCR Decrement Ratio 7-6 

TCR Event Select 7-6 

TCR Inverter Bit .... 7-7 

TCR Overflow Interrupt Enable ..... 7-6 

TCR Timer Enable 7-8 

TCR Timer Output Enable . 7-7 

TE 7-8 

Timer Architecture 7-3 

Timer Compare Register . . 1-16, 7-3, 7-5 
Timer Compare Register (TCPR) . . . C-24 



INDEX -6 
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Timer Control Register .... 1-16, 7-3, 7-6 — Y- 



Tlmer Control Register (TCR) .C-24 

Timer Count Register 1-16, 7-3 

Timer Count Register (TCTR) C-24 

Timer Functional Description 7-8 

Timer Input 2-12 

Timer Preload Register 1-16, 7-3, 7-4 
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